当前位置:首页 > PHP文摘 > 列表

Dedecms怎么使用arclist标签中idlist进行文章排序

发布:smiling 来源: PHP粉丝网  添加日期:2019-01-14 14:28:55 浏览: 评论:0 

平时小编在dedecms技术群里面看见站长朋友们做站的时候,排序总是一个头痛的问题,DedeCMS默认的文章排序功能已经非常强大了,但是唯一缺少的就是,按指定的id顺序排序,小编今天想着这个问题就睡不着,经过左思右百度,终于把这个问题解决了,DedeCMS默认的arclist标签有一个idlist调用指定id的文章,所以小编就想到了,就利用这个idlist进行排序,下面先上方法,再说原理。先打开/include/taglib/arclist.lib.php 所有的修改都是在这里面完成的。

1、找到return lib_arclistDone 这段代码,在其前面加上$orderidlist = $ctag->GetAtt(‘orderidlist’); 并且在lib_arclistDone函数调用的最后面加上参数$orderidlist,代码如下:

  1. $orderidlist = $ctag->GetAtt(‘orderidlist’); 
  2.  
  3. return lib_arclistDone 
  4.  
  5.  
  6. $refObj$ctag$typeid$ctag->GetAtt(‘row’), $ctag->GetAtt(‘col’), $titlelen$infolen
  7.  
  8. $ctag->GetAtt(‘imgwidth’), $ctag->GetAtt(‘imgheight’), $listtype$orderby
  9.  
  10. $ctag->GetAtt(‘keyword’), $innertext$envs[‘aid’], $ctag->GetAtt(‘idlist’), $channelid
  11. //phpfensi.com 
  12. $ctag->GetAtt(‘limit’), $flag,$ctag->GetAtt(‘orderway’), $ctag->GetAtt(‘subday’), $ctag->GetAtt(‘noflag’), 
  13.  
  14. $tagid,$pagesize,$isweight,$orderidlist 
  15.  
  16. ); 

2、找到function lib_arclistDone这段代码,在函数lib_arclistDone的最后加上参数$orderidlist=’N’,代码如下:

  1. function lib_arclistDone(&$refObj, &$ctag$typeid=0, $row=10, $col=1, $titlelen=30, $infolen=160, 
  2.  
  3. $imgwidth=120, $imgheight=90, $listtype=’all’, $orderby=’default’, $keyword=”, 
  4.  
  5. $innertext=”, $arcid=0, $idlist=”, $channelid=0, $limit=”, $att=”, $order=’desc’, $subday=0, $noflag=”,$tagid=”, $pagesize=0, $isweight=’N’,$orderidlist=’N’) 

3、找到$innertext = trim($innertext); ,在其下面加上$orderidlist = AttDef($orderidlist,’N’);代码如下:

  1. $orderby = strtolower($orderby); 
  2.  
  3. $keyword = trim($keyword); 
  4.  
  5. $innertext = trim($innertext); 
  6.  
  7. $orderidlist = AttDef($orderidlist,’N’); 
  8.  
  9. $tablewidth = $ctag->GetAtt(‘tablewidth’); 
  10.  
  11. $writer = $ctag->GetAtt(‘writer’); 
  12.  
  13. if($tablewidth == “”) $tablewidth = 100; 

4、搜索“//指定了id或使用缓存中的id” 把下面的条件语句改成:

  1. //指定了id或使用缓存中的id 
  2.  
  3. if($idlist != ”) 
  4.  
  5.  
  6. $query = “SELECT arc.*,tp.typedir,tp.typename,tp.corank,tp.isdefault,tp.defaultname,tp.namerule,tp.namerule2,tp.ispart, 
  7.  
  8. tp.moresite,tp.siteurl,tp.sitepath 
  9.  
  10. $addfieldsSql 
  11.  
  12. FROM `$maintable` arc left join `dede_arctype` tp on arc.typeid=tp.id 
  13.  
  14. $addfieldsSqlJoin 
  15.  
  16. WHERE arc.id in($idlist) “; 
  17.  
  18. if($orderidlist == ‘N’) { 
  19.  
  20. $query .= $ordersql
  21.  
  22. else { 
  23.  
  24. $query .= ” ORDER BY FIELD(arc.id,$idlist) “; 
  25. //phpfensi.com 
  26.  

这样就对arclist添加了一个orderidlist属性,有参数Y/N, 默认为N,为Y的时候,就可以按idlist 排序了。其实这个原理也非常简单,就是利用的MYSQL数据库的ORDER BY FIELD功能。所以这样我们就可以使用idlist排序了。

Tags: arclist idlist

分享到: