欢迎来到入门教程网!

dedecms

当前位置:主页 > CMS教程 > dedecms >

织梦DedeCMS获取当前栏目文章数量

来源:本站原创|时间:2021-08-05|栏目:dedecms|点击:311 次

使用织梦DedeCMS建站的时候,有时候需要对当前栏目及其所有子栏目的文档数量进行统计,方便反馈给用户。我们可以在织梦DedeCMS的模板 中使用SQL标签来实现,不过织梦DedeCMS为了系统的安全,加强了对SQL注入和安全的检查,导致无法查询一些正常的子查询的SQL。
那怎么实现获取当前栏目及其所有子栏目的文档数量的功能呢?我们可以使用自定义函数解决。No牛网把方法整理如下,修改织梦程序include/common.func.php文件,在最后加以下代码:
 
//统计栏目文章数 www.moke8.com
function GetTotalArc($tid)
global $dsql;
$sql = GetSonIds($tid);
$row = $dsql->GetOne("Select count(id) as dd From `dede_archives` where typeid
in($sql)");
return $row'dd';
//统计当前栏目信息数
function dynamic_num($current_id)
global $dsql;
//读取当前栏目的子ID
$sql = "SELECT id FROM `dede_arctype` WHERE id='$current_id' ||
topid='$current_id'";
$dsql->SetQuery($sql);
$dsql->Execute();
while($row = $dsql->GetArray())
$arr=$row;
foreach($arr as $key=>$value)
$type .= $value . ',';
$ty= "".$type."0";
//echo $ty;
$t_num = $dsql->GetOne("select count(*) as num from `dede_archives` where typeid
in($ty)");
//echo $t_num;
if(is_array($t_num))
return " ".$t_num." ";
else
return "0" ;
以上代码就是新增了两个函数,一个统计栏目文章数,另一个统计当前栏目信息数,在织梦dedecms模板中可以和调用系统函数一样调用他们。如使用如下的调用代码:
 
dede:field name=’typename’/</b>(该类拥有dede:typefield:id
function="dynamic_num(@me)" //dede:type个文档)
dede:channel type=’son’
<li><a href=’field:typelink/‘>field:typename/</a>(<span>field:ID
runphp='yes' @me = GetTotalArc(@me);/field:ID</span>)</li>
/dede:channel

上一篇:织梦模板如何添加和调用自定义字段的方法

栏    目:dedecms

下一篇:Dedecms5.7版ckeditor网页编辑器添加中文字体

本文标题:织梦DedeCMS获取当前栏目文章数量

本文地址:https://www.xiuzhanwang.com/a1/dedecms/17032.html

更多dedecms

您可能感兴趣的文章

阅读排行

本栏相关

随机阅读

网页制作CMS教程网络编程软件编程脚本语言数据库服务器

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:835971066 | 邮箱:835971066#qq.com(#换成@)

Copyright © 2002-2020 脚本教程网 版权所有