加入收藏 | 设为首页 | 会员中心 | 我要投稿 宿州站长网 (https://www.0557zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 建站 > 正文

DedeCMS sql 调用数字递增标签以及修改方案

发布时间:2022-06-04 14:53:55 所属栏目:建站 来源:互联网
导读:在{dede:arclist/}这个标签中大家都知道有个[field:global.autoindex/] ,这个变量每生成一行就+1,那很多人希望{dede:sql/}标签也需要加上这个功能,很多朋友提问,肯定会认为官方不会去做,其实不然,官方主要希望大家能够一同分享这种使用、开发的小技巧
        在{dede:arclist/}这个标签中大家都知道有个[field:global.autoindex/] ,这个变量每生成一行就+1,那很多人希望{dede:sql/}标签也需要加上这个功能,很多朋友提问,肯定会认为官方不会去做,其实不然,官方主要希望大家能够一同分享这种使用、开发的小技巧,小经验,其实这个东西很简单,自己稍微摸索下就可以知道。
 
       下面我们就开始增加这个小扩展,我们知道在V5.3中织梦的标签已经分离出来,也就是类似于arclist这样的标签可以自己修改或者二次开发,程序这些标签存放的目录在/include/taglib文件夹下面,我们可以看那个文件名,就很容易知道这些标签文件名和标签的对应关系。
 
        那我们现在需要修改的是{dede:sql/}这个标签,那我们就修改sql.lib.php这个文件。
        打开后我们找到第34行,也就是代码
 
$ctp->LoadSource($Innertext);
 
处,在下面加上以下一段代码:
 
$GLOBALS['autoindex'] = 0;
 
这段代码就是定义一个全局变量,并赋值为0,接下来我们只需要将下面代码进行下修改:
 
复制代码代码如下:
 
while($row = $dsql->GetArray($thisrs))
{
$sqlCt++;
foreach($ctp->CTags as $tagid=>$ctag){
if(!empty($row[$ctag->GetName()])){ $ctp->Assign($tagid,$row[$ctag->GetName()]); }
}
$GLOBALS['autoindex']++; //每循环一次加上一个1然后解析出来
$revalue .= $ctp->GetResult();
}
 
这样一来,这个[field:global.autoindex/]标签就可以在那个{dede:sql/}中使用了,我们举个例子:
 
复制代码代码如下:
 
{dede:sql sql='select * from [url=mailto:dede_archives]dede_archives'[/url]}
[field:global.autoindex/]-[field:title/]</br>
{/dede:sql}
 
怎么样?很简单吧,其实这种扩展还有很多很多,自己可以试试哦。

(编辑:宿州站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!