DedeCMS 如何在{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 dede_archives'} [field:global.autoindex/]-[field:title/]</br> {/dede:sql}
怎么样?很简单吧,其实这种扩展还有很多很多,自己可以试试哦。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。