找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 211|回复: 0

[cms教程] 让dedecms子栏目的调用及其文章数量统计

[复制链接]

该用户从未签到

发表于 2021-8-7 09:43:48 | 显示全部楼层 |阅读模式

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

×
调用当前栏目的子栏目列表:以下三段任选。
         
       
               
                       
                               
                                       
{dede:sonchannel}  
[url=[field:typeurl/],[field:typename/][/url]  
{/dede:sonchannel}  
                               
                       
               
       

         
       
               
                       
                               
                                       
{dede:channel type='son' noself='yes'}  
[*,[url=,[field:typename/][/url]  
{/dede:channel}  
                               
                       
               
       

         
         
       
               
                       
                               
                                       
{dede:channel type='son' typeid=‘栏目ID’ noself='yes'}  
[*,[url=,[field:typename/][/url]  
{/dede:channel}  
                               
                       
               
       

         
        子栏目的文章数量统计:
        在/include/extend.func.php最下方处添加以下代码:
         
       
               
                       
                               
                                       
/*   
* 返回符合记录的文章数量   
* @description DEDE不允许执行子查询,解决栏目下文章统计的问题   
* @param $level 为真时查询所有子类目   
* */   
function getTotalArcByTid($tid, $level=TRUE) {   
global $dsql;   
$level==TRUE && $tid = GetSonTypeID($tid);   
$sql = "SELECT count(id) as total from `dede_archives` where typeid in($tid)";   
$result = $dsql->GetOne($sql);   
return $result['total',;   
}   
/*   
* 递归获取符合条件的子栏目   
* @param $tid 栏目ID   
* @return string   
* */   
function GetSonTypeID($tid)   
{   
global $dsql;   
$dsql->SetQuery("Select id From `dede_arctype` where reid in($tid) And ishidden1 order by sortrank");   
$dsql->Execute($tid);   
$typeid = '';   
while($row=$dsql->GetObject($tid))   
{   
$typeid .= "{$row->id},";   
$typeid .= GetSonTypeID($row->id);   
}   
return trim($typeid,',');   
}   
                               
                       
               
       

         
        然后用这个标签调用:
         
        {dede:field.typeid function="getTotalArcByTid(@me)"/}   
         
        [field:typeid function="getTotalArcByTid(@me)"/]
回复

使用道具 举报

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

GMT+8, 2024-11-26 21:45

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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