手机
当前位置:查字典教程网 >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 获取当前栏目及所有子栏目的文章数量】相关文章:

织梦DEDECMS中要删除指定IP的评论的方法

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

DEDECMS中获取无限栏目子分类的方法

dedecms 取消栏目列表页文章标题设置推荐后的加粗

dede增加批量删除采集内容的方法

DEDECMS鼠标移上显示全部标题的方法

DEDECMS在PHP5.4不能正常运行的解决方法

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

DEDE软件及分类信息的采集方法

DEDECMS网站文章列表页更新点击次数的问题完美解决

精品推荐
分类导航