151-3895-5886
 

织梦DedeCMS模板使likearticle标签支持排序orderby的方法

2018-10-31 浏览:
我们在使用织梦DedeCMS模版用于图片站WEB开发时,需要随机调用文章、图集和关联文章、图集功能,以增加用户黏度,这个也属于站内优化重要一部分。
织梦CMS
一般用标签调用都有排序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这个功能。今天我们想给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的值即可实现按增加需要的方式进行排序
 
郑州融科网络专注于企业网站建设、网站制作、高端网站设计,郑州荥阳、上街做网站就找融科网络!
本文章网址:http://www.ppssdd.com/code/1527.html。转载请保留出处,谢谢合作!
文章标签: 模板 标签 代码 织梦 dedecms 文章 排序
 
阅读下一篇
织梦后DedeCMS台文件任意上传漏洞media_add.php的修改方法
 
 
推荐阅读
什么是单页网站?单面网站如何进
中学生打字速度慢的原因及解决办
上街网站建设浅谈网站优化的弊端
网站运营过程中会遇到的瓶颈问题
网站制作过程中遇到QQ在线客服出现
网站的分页导航应该怎么设计
织梦dedecms有shorttitle则显示,没有则
郑州企业网站微信如何利用微网站
如何编辑新颖网站内容?不要把过
学习网页设计要注意哪几个要点
郑州网站建设融科网络微信二维码
 
准备开展业务?
郑州建站咨询服务
联系专业的商务顾问,诊查网站现状及关键词、分析竞争对手的流量、一对一咨询、及其报价详情