DedeCMS文章arclist标签按指定idlist列表排序

  • 编辑时间:2016-08-27
  • 浏览量:
  • 作者:新乡网站建设
    给客户做企业网站的时候,产品排序总是一个头痛的问题,DedeCMS默认的文章排序功能已经非常强大了,但是唯一缺少的就是,按指定的id顺序排序,经过左思右百度,终于把这个问题解决了,DedeCMS默认的arclist标签有一个idlist调用指定id的文章,所以我就想到了,就利用这个idlist进行排序,下面直接说方法。先打开/include/taglib/arclist.lib.php ,所有的修改都是在这里面完成的。
 
    第一步:找到return lib_arclistDone 这段代码 ,在其前面加上$orderidlist = $ctag->GetAtt('orderidlist');   并且在lib_arclistDone函数调用的最后面加上参数$orderidlist,结果如下
 
$orderidlist = $ctag->GetAtt('orderidlist');
 
return lib_arclistDone
 
       (
 
         $refObj, $ctag, $typeid, $ctag->GetAtt('row'), $ctag->GetAtt('col'), $titlelen, $infolen,
 
         $ctag->GetAtt('imgwidth'), $ctag->GetAtt('imgheight'), $listtype, $orderby,
 
         $ctag->GetAtt('keyword'), $innertext, $envs['aid'], $ctag->GetAtt('idlist'), $channelid,
 
         $ctag->GetAtt('limit'), $flag,$ctag->GetAtt('orderway'), $ctag->GetAtt('subday'), $ctag->GetAtt('noflag'),
 
         $tagid,$pagesize,$isweight,$orderidlist
 
       );
 
    第二步:找到function lib_arclistDone这段代码,在函数lib_arclistDone的最后加上参数$orderidlist='N' ,结果如下:
 
function lib_arclistDone(&$refObj, &$ctag, $typeid=0, $row=10, $col=1, $titlelen=30, $infolen=160,
 
        $imgwidth=120, $imgheight=90, $listtype='all', $orderby='default', $keyword='',
 
        $innertext='', $arcid=0, $idlist='', $channelid=0, $limit='', $att='', $order='desc', $subday=0, $noflag='',$tagid='', $pagesize=0, $isweight='N',$orderidlist='N')
 
    第三步:找到$innertext = trim($innertext); ,在其下面加上$orderidlist = AttDef($orderidlist,'N'); 结果如下:
 
$orderby = strtolower($orderby);
 
$keyword = trim($keyword);
 
$innertext = trim($innertext);
 
$orderidlist = AttDef($orderidlist,'N');
 
$tablewidth = $ctag->GetAtt('tablewidth');
 
$writer = $ctag->GetAtt('writer');
 
if($tablewidth == "") $tablewidth = 100;
 
    第四步:搜索“//指定了id或使用缓存中的id”  把下面的条件语句改成:
 
//指定了id或使用缓存中的id
 
if($idlist != '')
 
{
 
   $query = "SELECT arc.*,tp.typedir,tp.typename,tp.corank,tp.isdefault,tp.defaultname,tp.namerule,tp.namerule2,tp.ispart,
 
        tp.moresite,tp.siteurl,tp.sitepath
 
        $addfieldsSql
 
         FROM `$maintable` arc left join `dede_arctype` tp on arc.typeid=tp.id
 
         $addfieldsSqlJoin
 
      WHERE arc.id in($idlist) ";
 
   if($orderidlist == 'N') {
 
        $query .= $ordersql;
 
   } else {
 
        $query .= " ORDER BY FIELD(arc.id,$idlist) ";
 
   }         
 
}
 
    OK,这样就对arclist添加了一个orderidlist属性,有参数Y/N, 默认为N,为Y的时候,就可以按idlist 排序了,然后就可以用下面这一段代码进行测试,对比加上orderidlist=‘Y’之后的区别。
 
 
{dede:arclist  idlist='6,7,10,3,5,2'}
 
[field:id/] [field:title/]
 
{/dede:arclist}
 
--------------------------------------
 
{dede:arclist  idlist='6,7,10,3,5,2'  orderidlist='Y'}
 
[field:id/] [field:title/]
 
{/dede:arclist}
 
-------------------------------------------------------------------------------------------
-------------------------------------------------------------------------------------------