找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 128|回复: 0

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

[复制链接]

该用户从未签到

发表于 2019-4-26 10:44:49 | 显示全部楼层 |阅读模式

您需要 登录 才可以下载或查看,没有账号?立即注册

×
如何在{dede:sql}这个标签中使用[field:global.autoindex/]
         
        在{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/]
        {/dede:sql}
         
        怎么样?很简单吧,其实这种扩展还有很多很多,自己可以试试哦。
回复

使用道具 举报

网站地图|页面地图|文字地图|Archiver|手机版|小黑屋|找资源 |网站地图

GMT+8, 2024-11-29 06:47

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表