织梦模板用{dede:sql}标签如何实现分页的示例代码

所属分类: CMS教程 / dedecms 阅读数: 434
收藏 0 赞 0 分享

近研究了一下织梦CMS系统,看到一篇关于sql标签调用数据列表如何翻页的文章,感觉不错,贴出来大家分享一下。相信很多使用dedecms的朋友在网上查找关于dede:sql标签进行分页的解决方案时都不尽如人意,尤其是在列表页使用dede:sql调用外部数据(所谓调用外部数据就是指在后台只是创建个空栏目,然后对应的列表模板文件中使用dede:sql指定自定义的数据源,数据源与该栏目本身是没有逻辑关系的,目的是为了让织梦能按照它的规则来帮我们将数据源生成静态文件予以展示)时,我本人也搜索了很多资料,网上的答案都不够完美,有的是直接在模板文件中执行php代码来实现分页,显然此方法无法生成静态文件,有的直接在sql里面指定limit参数,但又无法实现智能分页,织梦官方也没有给出具体的解决方案,在dede论坛有看到织梦核心人物天涯给出的回复是采用自由列表的方法,显然自由列表无法指定外部数据源,最后实在没办法只能自己动手了,首先想到的思路是将dede:list标签进行改造了,熟悉dede的朋友应该知道这个列表页专用标签的工作原理大致是先通过栏目变量id获取到对应的数据源再呈现到页面上来,那么我们就可以让它不仅仅通过栏目变量id还可以通过指定的sql语句来获取数据源了,比如我们可以另外嵌入一个类似{dede:listsql sql='select * from wp_posts' pagesize='10'}的标签来使用。

OK,思路已经有了,接下来我们打开include/arc.listview.class.php这个文件来给它动个小手术吧!

找到:

if(!is_object($ctag))
{
 $ctag = $this->dtp->GetTag("list");
}

这一段,在其后添加如下代码:

if(!is_object($ctag))
{
 $ctag = $this->dtp->GetTag("listsql");
 if (is_object($ctag))
 {
  $cquery = $ctag->GetAtt("sql");
  $cquery = preg_replace("/SELECT(.*?)FROM/is", " SELECT count(*) as dd FROM ", $cquery);
  $cquery = preg_replace("/ORDER(.*?)SC/is", "", $cquery);
  $row = $this->dsql->GetOne($cquery);
  if(is_array($row))
  {
   $this->TotalResult = $row['dd'];
  }
  else
  {
   $this->TotalResult = 0;
  }
 }
}
//end

然后找到:

if($ctag->GetName()=="list")
   {
    $limitstart = ($this->PageNo-1) * $this->PageSize;
    $row = $this->PageSize;
    if(trim($ctag->GetInnerText())=="")
    {
     $InnerText = GetSysTemplets("list_fulllist.htm");
    }
    else
    {
     $InnerText = trim($ctag->GetInnerText());
    }
    $this->dtp->Assign($tagid,
    $this->GetArcList(
    $limitstart,
    $row,
    $ctag->GetAtt("col"),
    $ctag->GetAtt("titlelen"),
    $ctag->GetAtt("infolen"),
    $ctag->GetAtt("imgwidth"),
    $ctag->GetAtt("imgheight"),
    $ctag->GetAtt("listtype"),
    $ctag->GetAtt("orderby"),
    $InnerText,
    $ctag->GetAtt("tablewidth"),
    $ismake,
    $ctag->GetAtt("orderway")
    )
    );
   }

这一段,在其后添加如下代码:

else if($ctag->GetName()=="listsql")
 {
  $limitstart = ($this->PageNo-1) * $this->PageSize;
  $row = $this->PageSize;
  if(trim($ctag->GetInnerText())=="")
  {
   $InnerText = GetSysTemplets("list_fulllist.htm");
  }
  else
  {
   $InnerText = trim($ctag->GetInnerText());
  }
  $this->dtp->Assign($tagid,
  $this->GetSqlList(
  $limitstart,
  $row,
  $ctag->GetAtt("sql"),
  $InnerText
  )
  );
 }
 //end

最后找到function GetArcList这个方法,在其后添加一个可以通过传入sql参数获取指定数据源的方法,代码如下:

/**
 * 通过listsql标签中sql属性传入的参数来获得一个单列的文档列表
 * */
function GetSqlList($limitstart = 0, $row = 10, $sql = '', $innertext){
 global $cfg_list_son;
 $innertext = trim($innertext);
 if ($innertext == '') {
  $innertext = GetSysTemplets('list_fulllist.htm');
 }
 //处理SQL语句
 $limitStr = " LIMIT {$limitstart},{$row}";
 $this->dsql->SetQuery($sql . $limitStr);
 $this->dsql->Execute('al');
 $t2 = ExecTime();
 //echo $t2-$t1;
 $sqllist = '';
 $this->dtp2->LoadSource($innertext);
 $GLOBALS['autoindex'] = 0;
 //获取字段
 while($row = $this->dsql->GetArray("al")) {
  $GLOBALS['autoindex']++;
  if(is_array($this->dtp2->CTags))
  {
   foreach($this->dtp2->CTags as $k=>$ctag)
   {
    if($ctag->GetName()=='array')
    {
     //传递整个数组,在runphp模式中有特殊作用
     $this->dtp2->Assign($k,$row);
    }
    else
    {
     if(isset($row[$ctag->GetName()]))
     {
      $this->dtp2->Assign($k,$row[$ctag->GetName()]);
     }
     else
     {
      $this->dtp2->Assign($k,'');
     }
    }
   }
  }
  $sqllist .= $this->dtp2->GetResult();
 }//while
 $t3 = ExecTime();
 //echo ($t3-$t2);
 $this->dsql->FreeResult('al');
 return $sqllist;
}
//end

总共就添加三段代码,每一段代码基本都参考它紧接着的上面那段原始代码,而无需改变它原来任何一个地方的代码,应该算是比较完美了,接下来在模板文件中的使用方法就跟一开始思路中所提到的那样,分页标签依旧沿用原来的,调用范例:

{dede:listsql sql='select ID,post_title from wp_posts' pagesize='10'}
 
<li><a href="[field:ID /].html">[field:post_title /]</a></li>
 
{/dede:listsql}
 
<!--分页-->
 
{dede:pagelist listsize='2' listitem='index pre pageno next end '/}

注:以上解决方案适用于dedecms5.6-5.7版本。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

更多精彩内容其他人还在看

织梦dedecms 忘记管理员后台密码的解决技巧

好多情况下,由于各种原因忘记了dedecms的密码,给大家带来了很大的麻烦,官方也没有出直接修改密码的东西可能是为了安全考虑吧。下面是最根本的方法,需要的朋友可以参考下。
收藏 0 赞 0 分享

取消dedecms 留言簿的验证码的方法

有时候感觉加了验证码,为互动带来了麻烦,如果垃圾广告很少的话可以取消,下面是具体的实现方法。
收藏 0 赞 0 分享

DEDECMS相关文章不相关的解决办法

关键字描述:相关 办法 解决 文章   " < row-> ss &rsquo DEDE的相关文章完全不相关,有朋友在DEDE官方放出根据TAG显示相关文章,也是很不错,可惜我在根据那边文章改DEDE代码后老是不行,可能是能力有限,当然也有可能是代
收藏 0 赞 0 分享

Dedecms默认模板用户评论扩展

关键字描述:评论 扩展 用户 模板 默认 " < > class 登录 Dedecms默认模板内容页评论处有个不足的地方,就是用户登录之后还会出现那个提示用户登录的框子,天涯这里给出了以下解决方案,如果喜欢的朋友可以拿去。 首先我们给内容页模板写上一段
收藏 0 赞 0 分享

DEDE取消发表文章时去掉验证码

关键字描述:dede 取消 发表文章 验证码 网站 关闭 后台 我的一个DEDECMS的网站里面所有的东西都是自己发布的,所以不需要验证码! DEDE默认是有验证码的,而且后台是不能关闭的,所以我们需要对代码动下手术拉! 今天,小青就在xkzzz谈一谈如何将d
收藏 0 赞 0 分享

【Arclist 标记】--Dedecms模板标签代码

关键字描述:标签 代码 模板 标记 表示 文档 < " 属性 orderby 这个标记是DedeCms最常用的一个标记,也叫自由列表标记,其中 hotart、coolart、likeart、ar
收藏 0 赞 0 分享

Dedecms实时更新热门关键字!

关键字描述:关键字 热门 更新 实时 标记 Copy code < subday num Dedecms实时更新热门关键字其实实现起来很简单,可是很多人不知道。 登录到dedecms后台 后台:自定义宏标记 添加一标记: 所属栏目:默认不用动 标记名称:ke
收藏 0 赞 0 分享

从零学DedeCms模板教程

关键字描述:教程 模板 < 模版 代码 标记 &mdash 制作 field:title/ DedeCms真是一个非常棒的系统,我从接触到现在一年时间再也没有理会其他CMS系统,推荐刚开始建站或准备换程序的朋友使用DedeCms系统。就像柏拉图说的:利剑已出,天下必乱
收藏 0 赞 0 分享

dedecms制作的admin5的评论效果

dedecms制作的admin5的评论效果 哪位朋友修改后了 请出个演示 以便让其他朋友提供参考 谢谢 声明:大家下载后请先在本地调式,确定无误后再使用。请备份原文件 把附件一覆盖到 主目录plus文件夹下; 把附件二覆盖到
收藏 0 赞 0 分享

dede解决两个标题之间的空格问题

关键字描述:空格 问题 之间 标题 解决 两个 显示 dedecms 一行 没有 问题: dedecms想在一行显示多个标题,比如两个或者三个,标题之间不需要空格,但是dedecms默认的一行显示的标题间有空格 修改./include/inc_arcpart_view.
收藏 0 赞 0 分享
查看更多