网络建站知识发布于分享网站

当前位置:首页>>新闻中心>>CMS教程>>dedecms教程

DedeCMS {dede:sql} 标签分页教程

时间:2025-03-31 10:36:35    来源:    人气:1

在使用Dedecms的过程中,许多用户都希望找到一种完美的解决方案,以实现`dede:sql`标签的分页功能。尤其是在列表页中调用外部数据时,这一需求显得尤为重要。所谓调用外部数据,是指在后台创建一个空栏目,并在对应的列表模板文件中使用`dede:sql`标签指定自定义的数据源。这种数据源与栏目本身没有逻辑关系,目的是让Dedecms按照其规则生成静态文件并展示。 然而,在网上搜索相关解决方案时,往往会发现这些方法并不够理想。有些方法直接在模板文件中执行PHP代码来实现分页,但这种方法无法生成静态文件;还有些方法直接在SQL语句中指定`LIMIT`参数,但这种方式无法实现智能分页。Dedecms官方也未提供具体的解决方案,而在Dede论坛上,核心人物天涯建议使用自由列表的方法,但自由列表无法指定外部数据源。因此,我们需要自己动手解决问题。 ### 解决方案 我们可以对`dede:list`标签进行改造,使其不仅可以通过栏目变量ID获取数据源,还可以通过指定的SQL语句来获取数据源。例如,我们可以通过嵌入类似以下标签来实现:


{dede:listsql sql='select * from wp_posts' pagesize='10'}
接下来,我们将对Dedecms的核心文件进行修改。 --- #### 第一步:打开`include/arc.listview.class.php` 找到以下代码段: ```php if(!is_object($ctag)){$ctag = $this->dtp->GetTag("list");} ``` 在其后添加以下代码:

//add by Gump 2011-12-31
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;
    }
}
--- #### 第二步:继续修改`include/arc.listview.class.php` 找到以下代码段: ```php if($ctag->GetName()=="list"){ ... } ``` 在其后添加以下代码:

//add by Gump 2011-12-31
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));
}
--- #### 第三步:添加`GetSqlList`方法 最后,找到`function GetArcList`这个方法,在其后添加以下代码:

//add by Gump 2011-12-31
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();
    $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'){
                    $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();
    }
    $t3 = ExecTime();
    $this->dsql->FreeResult('al');
    return $sqllist;
}
--- ### 使用方法 完成上述修改后,可以在模板文件中使用以下代码实现分页功能:

{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 '/}
通过以上步骤,我们成功实现了`dede:sql`标签的分页功能,同时保留了Dedecms生成静态文件的能力。这种方法无需修改原有代码逻辑,是一种较为完美的解决方案。

相关文章

  • Dedecms 删除文档时同时清除文章中图片的方法

    Dedecms 删除文档时同时清除文章中图片的方法

    在网站建设与维护的过程中,优化代码结构和功能是提升网站性能的重要步骤。本文将介绍如何通过自定义函数实现文章删除时自动清理相关资源的功能,从而提高系统的整洁性和存储效率。以下是具体的操作步骤及代码实现。首先, 在 `/include` 目录下创建一个名为 `extend.func.php` 的文件...
    2025-03-31
  • Dedecms上传图片提示302错误ERROR的解决方法

    Dedecms上传图片提示302错误ERROR的解决方法

    在进行图片上传操作时,用户可能会遇到302错误以及带有ERROR提示的图片上传失败问题。这些问题可能由多种原因引发,因此本文将对这些情况进行整理,以帮助大家更有效地定位并解决问题。 第一种情况:图片文件本身损坏。 这种情况会导致系统返回ERROR错误提示,不过发生概率较低。如果怀疑是图片损坏导致的...
    2025-03-31
  • DEDECMS模板使用教程

    DEDECMS模板使用教程

    如果您正在寻找一种高效的方法来使用Dedecms模板搭建网站或论坛,那么本文将为您提供详尽的指导。从模板解压到最终完成配置,每一步都将清晰呈现,帮助您快速掌握整个流程。 第一步:解压Dedecms模板 将下载的Dedecms模板文件解压出来,确保所有文件完整无误。如下图所示: 第二步:获取D...
    2025-03-31
  • Dedecms Dede 附加表自定义字段与主表文章关联方法

    Dedecms Dede 附加表自定义字段与主表文章关联方法

    在使用DedeCMS开发装修网站时,设计师和设计作品之间的关联是一个重要的功能需求。通常情况下,文章(作品)的内容部分存储在主表dede_addonarticle中,而自定义字段则存储在附加表dede_archives中。为了实现这一功能,可以采用以下两种方法。 ① 根据发布人调用相关文章; ...
    2025-03-31

公众号