欢迎来到入门教程网!

dedecms

当前位置:主页 > CMS教程 > dedecms >

织梦DedeCMS使likearticle标签支持排序orderby

来源:本站原创|时间:2021-08-05|栏目:dedecms|点击:

我们在使用DedeCMS用于图片站WEB开发时,需要随机调用文章、图集和关联文章、图集功能,以增加用户黏度,这个也属于站内优化重要一部分。
 
DedeCMS使likearticle标签支持排序orderby
 
一般用标签调用都有排序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这个功能。淘站网以前在文章《DedeCMS通过Tag和Keyword标签获取相关文章的方法》和《DedeCMS文章页调用全站相关文章的方法》中也介绍过调用全站相关文章的方法,而今天我们想给likearticle也增加一个排序功能.
 
方法也很简单,打开/include/taglib/likearticle.lib.php,找到以下代码(大概在第97行):
 
 
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";
 
保存后,再在{dede:likearticle}标签中增加orderby的值即可实现按增加需要的方式进行排序。
 

上一篇:织梦标签array runphp静态生成乱码BUG解决方法

栏    目:dedecms

下一篇:织梦DedeCMS修改文章时取消提取第一张图片为缩略图

本文标题:织梦DedeCMS使likearticle标签支持排序orderby

本文地址:https://www.xiuzhanwang.com/a1/dedecms/16237.html

更多dedecms

您可能感兴趣的文章

阅读排行

本栏相关

随机阅读

网页制作CMS教程网络编程软件编程脚本语言数据库服务器

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:835971066 | 邮箱:835971066#qq.com(#换成@)

Copyright © 2002-2020 脚本教程网 版权所有