织梦DEDE怎么使用ARCLIST标签中IDLIST进行文章排序

织梦教程 强烈建议 2024-02-06 13:25 168 0
  平时看见站长朋友们做站的时候,排序总是一个头痛的问题,DedeCMS默认的文章排序功能已经***强大了,但是***缺少的就是,按指定的id顺序排序,小编经过左思右想,终于把这个问题解决了,DedeCMS默认的arclist标签有一个idlist调用指定id的文章,所以小编就想到了,就利用这个idlist进行排序,下面先上方法,再说原理。先打开/include/taglib/arclist.lib.php 所有的修改都是在这里面完成的。   1、找到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   );   2、找到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’)   3、找到$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;   4、搜索“//指定了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) “;   }   }   这样就对arclist添加了一个orderidlist属性,有参数Y/N, 默认为N,为Y的时候,就可以按idlist 排序了。其实这个原理也***简单,就是利用的MYSQL数据库的ORDER BY FIELD功能。所以这样我们就可以使用idlist排序了

时间:(2024-02-06 13:25:10)
本站资源均来自互联网或会员发布,如果不小心侵犯了您的权益请与我们联系。我们将立即删除!谢谢!