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

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

Dedecms Likearticle 标签实现随机排序的 Orderby 方法

时间:2025-03-31 13:05:24    来源:    人气:1

在进行网站开发时,特别是使用Dedecms CMS构建图片站,随机调用文章、图集以及关联内容的功能显得尤为重要。这不仅能够提升用户体验,还能增强用户黏性,是站内优化的关键环节之一。通常情况下,Dedecms 提供了多种标签来实现内容调用,例如 `{dede:arclist}` 标签支持通过 `orderby` 参数进行排序。


{dede:arclist orderby='rand'}
    [field:title/]
{/dede:arclist}
    

默认的 `orderby` 排序方式包括以下几种:
- `orderby='sortrank'`:按文档排序方式排列。
- `orderby='hot'` 或 `orderby='click'`:按点击数排列。
- `orderby='sortrank'` 或 `orderby='pubdate'`:按出版时间排列。
- `orderby='near'`:其他特定排序。
- `orderby='lastpost'`:按最后评论时间排列。
- `orderby='scores'`:按得分排序。
- `orderby='id'`:按文章ID排序。
- `orderby='rand'`:随机获取指定条件的文档列表。
然而,`{dede:likearticle}` 标签并不支持 `orderby` 功能。如果需要实现类似功能,则需要对系统文件进行修改。以下是具体的操作步骤: ### 修改方法 打开 `/include/taglib/likearticle.lib.php` 文件,找到以下代码段:

if( empty($arcid) || $byabs==0 ) {
    $orderquery = " order by arc.id desc ";
} else {
    $orderquery = " order by ABS(arc.id – ".$arcid.") ";
}
    
将其替换为以下代码:

if($orderby=='hot' || $orderby=='click') $orderquery = " order by arc.click $orderWay";
else if($orderby == 'sortrank' || $orderby=='pubdate') $orderquery = " orderby arc.sortrank $orderWay";
else if($orderby == 'id') $orderquery = " order by arc.id $orderWay";
else if($orderby == 'near') $orderquery = " order by ABS(arc.id – ".$arcid.")";
else if($orderby == 'lastpost') $orderquery = " order by arc.lastpost $orderWay";
else if($orderby == 'scores') $orderquery = " order by arc.scores $orderWay";
else if($orderby == 'rand') $orderquery = " order by rand()";
else if($orderby == 'weight') $orderquery = " order by arc.weight asc"; // 如果没有特定设置排序则按照权重先排序
else $orderquery = " order by arc.sortrank $orderWay";
    

通过上述修改,`likearticle` 标签将支持更多排序方式,例如按价格排序(适用于商城场景)。只需在代码最后一行前添加以下一行:

else if($orderby == 'trueprice') $ordersql = " order by addf.trueprice $orderWay";
    

此外,还可以实现主表自定义字段排序功能,例如通过 `{dede:arclist orderby='orderid'}` 调用自定义字段排序。具体操作如下: ### 数据库操作 使用 MySQL 管理工具或其他工具,修改 `dede_archives` 表结构,添加一列名为 `orderid` 的字段。 ### 后台文件操作 1. **修改 `article_add.php`**
在第 187 行,更新字段和接收文本值:

$query = "INSERT INTO `dede_archives`(id,typeid,typeid2,sortrank,flag,ismake,channel,arcrank,click,money,title,shorttitle,
color,writer,source,litpic,pubdate,senddate,mid,notpost,description,keywords,filename,dutyadmin,orderid)
VALUES ('$arcID','$typeid','$typeid2','$sortrank','$flag','$ismake','$channelid','$arcrank','$click','$money',
'$title','$shorttitle','$color','$writer','$source','$litpic','$pubdate','$senddate',
'$adminid','$notpost','$description','$keywords','$filename','$adminid','$orderid');";
    
2. **修改 `article_edit.php`**
在第 191 行后增加以下代码:

,orderid='$orderid'
    
3. **修改 `article_add.htm` 和 `article_edit.html`**
根据 HTML 知识自行调整相关字段。 ### 前台文件操作 1. **修改 `include/arc.listview.class.php`**
在第 551 至 555 行添加以下代码:

else if($orderby=="orderid") {
    $ordersql = " order by arc.orderid $orderWay";
}
    
2. **修改 `taglib` 中的 `arclist.lib.php`**
在第 235 行添加以下代码:

else if($orderby == 'orderid') $ordersql = " order by arc.orderid $orderWay";
    
完成以上步骤后,即可通过以下模板代码实现自定义字段排序:

{dede:arclist orderby='orderid' orderway='desc'}
    [这里是HTML部分]
{/dede:arclist}
    

相关文章

  • 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

公众号