亲测-phpcms的栏目缓存无限级罗列展示处理代码

技术教程 2026-01-09 15:34:47 浏览

代码如下:

{$a[$cid]['catname']}";if ($a[$cid]['parentid']) {//有父id//前面的在当前前面$n = array_merge(getNav($a[$cid]['parentid']), $n);}return $n;}$cid = (int)$_GET['cid'];$n = getNav($cid);echo "chrd>" .implode('>', $n);echo '

kkkkk

';function doTop($cid){//顶级的处理global $a;$n = array();$n[] = "{$a[$cid]['catname']}";//顶级本身//如果需要把同顶级的栏目罗列在这里处理return implode('|', $n);}function getSub($cid, $focusId = 0){//取子类+有父就递归global $a;$n = array();if (empty($a[$cid])) return $n;//数组无cid$pid = (int)$a[$cid]['parentid'];//父id$cs = $a[$cid]['arrchildid'];//子类id!empty($cs) && ($cs = explode(',', $cs) );if (empty($pid)) {//顶级父类处理$n[] = doTop($cid);} else {//有父类$n = array_merge(getSub($pid, $cid), $n);//合并时,父条在前}if (!empty($cs)) {//有子类$sn = array();$pInSub = 0;$sub = 0;//是否有子类Foreach ($cs as $c) {//只使用子类,顶级及本身与孙类排除if (0 == $c ){ //顶级?//echo '0';continue;}if (empty($a[$c])) { //数组中没保存到//echo '2';continue;}if ($cid == $c) {//本身//echo '3';continue;}if ($cid != $a[$c]['parentid']) {//孙级,pid不是自己//echo 'p';continue;}$sub = 1;//有子类if ( $focusId && ($focusId == $c) ) {$pInSub = 1;//是否出现在子类中$lf = '[';$rf = ']';} else {$lf = $rf = '';}$sn[] = "{$lf}{$a[$c]['catname']}{$rf}";}if (!$pInSub) {//不出现在子类中,高亮全部$lf = '[';$rf = ']';} else {$lf = $rf = '';}$all = $sub ? "{$lf}全部{$rf}|" : '';//本子类的全部就是本子类的上级$n[] = $all. implode('|', $sn);}return $n;}$n = getSub($cid);echo empty($n) ? '无' : implode('
', $n);

栏目缓存 如果有必要可以转化成js的处理.听说seo不懂js.想法是把它们的链接先include到html中,只给搜索引擎捉?再js处理这块, 临时帮同事写的,详细的考虑没有想.粗测试了一下,应该没有问题.

本文版权声明本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,请联系本站客服,一经查实,本站将立刻删除。

发表评论

热门推荐