我们在使用DedeCMS织梦模版用于图片站WEB开发时,需要随机调用文章、图集和关联文章、图集功能,以增加用户黏度,这个也属于站内优化重要一部分。

 

一般用标签调用都有排序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的值即可实现按增加需要的方式进行排序


THE END

本站部分文章搜集整理于互联网或者网友提供,如有侵权请联系站长

如若转载,请注明出处:https://htmlbk.com/dedecms/8.html

温馨提示:该文档最后一次修改时间为2018-12-28 08:41:45,请注意相关的内容是否还可用!

TAG标签:DedeCMS教程