手机
当前位置:查字典教程网 >CMS教程 >dedecms >DEDECMS 获取当前栏目及所有子栏目的文章数量
DEDECMS 获取当前栏目及所有子栏目的文章数量
摘要:以下代码用来解决查询当前栏目及当前栏目下所有子栏目的文章总数,添加到/include/common.func.php或者/include/e...

以下代码用来解决查询当前栏目及当前栏目下所有子栏目的文章总数,添加到/include/common.func.php

或者

/include/extend.func.php中,然后在模板中调用getTotalArcByTid(1)。

/*

* 返回符合记录的文章数量

* @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 ishidden<>1 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)"/]

【DEDECMS 获取当前栏目及所有子栏目的文章数量】相关文章:

织梦CMS调用问答栏目文章到首页实现方法分享

dedeCMS使用arclist标签调用自定义字段的方法

DedeCms后台登录一片空白的解决方法

让DEDECMS自动内链起来的实现方法

dedecms获取当前文档url地址的方法

dedecms 调用单页栏目内容到首页的方法

织梦 DeDeCMS 添加自定义属性的方法(图文教程)

dedecms调用当前栏目ID与当前栏目顶级ID的方法

DEDECMS v5.3 发布图集时不能获取缩略图的解决办法

在dedecms文章页中获取当前栏目字段如content字段

精品推荐
分类导航