如何在{dede:sql}这个标签中使用自增函数[field:global.autoindex/]

如何在{dede:sql}这个标签中使用[field:global.autoindex/]

在{dede:arclist/}这个标签中大家都知道有个[field:global.autoindex/],这个变量每生成一行就+1,那很多人希望{dede:sql/}标签也需要加上这个功能,很多朋友提问,肯定会认为官方不会去做,其实不然,官方主要希望大家能够一同分享这种使用、开发的小技巧,小经验,其实这个东西很简单,自己稍微摸索下就可以知道。

下面我们就开始增加这个小扩展,我们知道在V5.3中织梦的标签已经分离出来,也就是类似于arclist这样的标签可以自己修改或者二次开发,程序这些标签存放的目录在/include/taglib文件夹下面,我们可以看那个文件名,就很容易知道这些标签文件名和标签的对应关系。

那我们现在需要修改的是{dede:sql/}这个标签,那我们就修改sql.lib.php这个文件。
打开后我们找到第34行,也就是代码

  1. $ctp->LoadSource($Innertext);

处,在下面加上以下一段代码:

  1. $GLOBALS['autoindex'] = 0;

这段代码就是定义一个全局变量,并赋值为0,接下来我们只需要将下面代码进行下修改:

  1. while($row = $dsql->GetArray($thisrs))
  2. {
  3. $sqlCt++;
  4. foreach($ctp->CTags as $tagid=>$ctag){
  5. if(!empty($row[$ctag->GetName()])){ $ctp->Assign($tagid,$row[$ctag->GetName()]); }
  6. }
  7. $GLOBALS['autoindex']++; //每循环一次加上一个1然后解析出来
  8. $revalue .= $ctp->GetResult();
  9. }

这样一来,这个[field:global.autoindex/]标签就可以在那个{dede:sql/}中使用了,我们举个例子:

  1. {dede:sql sql='select * from [url=mailto:dede_archives]dede_archives'[/url]}
  2. [field:global.autoindex/]-[field:title/]</br>
  3. {/dede:sql}

怎么样?很简单吧,其实这种扩展还有很多很多,自己可以试试哦。

版权免责声明

① 本站VIP源码资源永久免费下载 www.wayu.cn
② 本网站资源来源于网络收集,如有侵权,请联系站长进行删除处理。
③ 分享目的仅供大家学习和交流,请不要用于商业用途,否则后果自负。
④ 如果你有源码需要出售,可以联系小编,或者点击 投稿
⑤ 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解。
⑥ 本站资源售价只是赞助,收取费用仅维持本站的日常运营所需。
⑦ 在您的能力范围内,为了大环境的良性发展,请尽可能的选择正版资源。
⑧ 网站资源不做任何二次加密和授权后门(原版加密除外)

评论0

请先

没有账号? 忘记密码?