找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 96|回复: 0

[cms教程] phpcms的栏目缓存无限级罗列展示处理代码(亲测)

[复制链接]

该用户从未签到

发表于 2019-3-24 16:11:00 | 显示全部楼层 |阅读模式

您需要 登录 才可以下载或查看,没有账号?立即注册

×
phpcms的栏目缓存无限级罗列展示处理代码(亲测)
复制代码代码如下:
" .implode('>', $n);
echo 'kkkkk
';
function doTop($cid){//顶级的处理
global $a;
$n = array();
$n[, = "[url=,{$a[$cid,['catname',}[/url]";//顶级本身
//如果需要把同顶级的栏目罗列在这里处理
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}[url=,{$a[$c,['catname',}[/url]{$rf}";
}
if (!$pInSub) {//不出现在子类中,高亮全部
$lf = '[';
$rf = ',';
} else {
$lf = $rf = '';
}
$all = $sub ? "{$lf}[url=,全部[/url]{$rf}|" : '';//本子类的全部就是本子类的上级
$n[, = $all. implode('|', $sn);
}
return $n;
}
$n = getSub($cid);
echo empty($n) ? '无' : implode('', $n);
如果有必要可以转化成js的处理.听说seo不懂js.想法是把它们的链接先include到html中,只给搜索引擎捉?再js处理这块,
展现效果大概如下

                               
登录/注册后可看大图


临时帮同事写的,详细的考虑没有想.粗测试了一下,应该没有问题.
回复

使用道具 举报

网站地图|页面地图|文字地图|Archiver|手机版|小黑屋|找资源 |网站地图

GMT+8, 2024-10-5 13:30

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表