DEDECMS怎么使用ARCLIST标签中IDLIST进行文章排序

平时星速云看见站长朋友们做站的时候,排序总是一个头痛的问题,DedeCMS默认的文章排序功能已经非常强大了,但是唯一缺少的就是,按指定的id顺序排序,星速云小编经过左思右想,终于把这个问题解决了,DedeCMS默认的arclist标签有一个idlist调用指定id的文章,所以星速云小编就想到了,就利用这个idlist进行排序,下面先上方法,再说原理。先打开/include/taglib/arclist.lib.php 所有的修改都是在这里面完成的。1、找到return lib_arclistDone 这段代码,在其前面加上$orderidlist = $ctag->GetAtt(‘orderidlist&rsquo😉; 并且在lib_arclistDone函数调用的最后面加上参数$orderidlist,代码如下:$orderidlist = $ctag->GetAtt(‘orderidlist&rsquo😉;return lib_arclistDone($refObj, $ctag, $typeid, $ctag->GetAtt(‘row&rsquo😉, $ctag->GetAtt(‘col&rsquo😉, $titlelen, $infolen,$ctag->GetAtt(‘imgwidth&rsquo😉, $ctag->GetAtt(‘imgheight&rsquo😉, $listtype, $orderby,$ctag->GetAtt(‘keyword&rsquo😉, $innertext, $envs[‘aid’], $ctag->GetAtt(‘idlist&rsquo😉, $channelid,$ctag->GetAtt(‘limit&rsquo😉, $flag,$ctag->GetAtt(‘orderway&rsquo😉, $ctag->GetAtt(‘subday&rsquo😉, $ctag->GetAtt(‘noflag&rsquo😉,$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&rsquo😉3、找到$innertext = trim($innertext); ,在其下面加上$orderidlist = AttDef($orderidlist,’N&rsquo😉;代码如下:$orderby = strtolower($orderby);$keyword = trim($keyword);$innertext = trim($innertext);$orderidlist = AttDef($orderidlist,’N&rsquo😉;$tablewidth = $ctag->GetAtt(‘tablewidth&rsquo😉;$writer = $ctag->GetAtt(‘writer&rsquo😉;if($tablewidth == “&rdquo😉 $tablewidth = 100;4、搜索“//指定了id或使用缓存中的id” 把下面的条件语句改成://指定了id或使用缓存中的idif($idlist != &rdquo😉{$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$addfieldsSqlFROM `$maintable` arc left join `dede_arctype` tp on arc.typeid=tp.id$addfieldsSqlJoinWHERE arc.id in($idlist) “;if($orderidlist == ‘N&rsquo😉 {$query .= $ordersql;} else {$query .= ” ORDER BY FIELD(arc.id,$idlist) “;}}这样就对arclist添加了一个orderidlist属性,有参数Y/N, 默认为N,为Y的时候,就可以按idlist 排序了。其实这个原理也非常简单,就是利用的MYSQL数据库的ORDER BY FIELD功能。所以这样我们就可以使用idlist排序了

注明:本文为星速云原创版权所有,禁止转载,一经发现将追究版权责任!

(0)
上一篇 2022年5月30日 上午4:00
下一篇 2022年5月30日 上午4:00

相关推荐

发表评论

登录后才能评论
问答社区 QQ客服
微信客服
微信客服
分享本页
返回顶部