找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 2167|回复: 0

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

[复制链接]
发表于 2018-7-28 11:09:38 | 显示全部楼层 |阅读模式 来自 中国–河南–新乡
站长朋友们做站的时候,排序总是一个头痛的问题,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. return lib_arclistDone
  3. (
  4. $refObj, $ctag, $typeid, $ctag->GetAtt(‘row’), $ctag->GetAtt(‘col’), $titlelen, $infolen,
  5. $ctag->GetAtt(‘imgwidth’), $ctag->GetAtt(‘imgheight’), $listtype, $orderby,
  6. $ctag->GetAtt(‘keyword’), $innertext, $envs[‘aid’], $ctag->GetAtt(‘idlist’), $channelid,
  7. $ctag->GetAtt(‘limit’), $flag,$ctag->GetAtt(‘orderway’), $ctag->GetAtt(‘subday’), $ctag->GetAtt(‘noflag’),
  8. $tagid,$pagesize,$isweight,$orderidlist
  9. );
复制代码


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. $imgwidth=120, $imgheight=90, $listtype=’all’, $orderby=’default’, $keyword=”,
  3. $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. $keyword = trim($keyword);
  3. $innertext = trim($innertext);
  4. $orderidlist = AttDef($orderidlist,’N’);
  5. $tablewidth = $ctag->GetAtt(‘tablewidth’);
  6. $writer = $ctag->GetAtt(‘writer’);
  7. if($tablewidth == “”) $tablewidth = 100;
复制代码


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

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

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

发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;

如何回报帮助你解决问题的坛友,好办法就是点击帖子下方的评分按钮给对方加【金币】不会扣除自己的积分,做一个热心并受欢迎的人!

▶专业解决各类DiscuzX疑难杂症、discuz版本升级 、网站搬家 和 云服务器销售!▶有偿服务QQ 860855665 更多精品应用
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则 需要先绑定手机号

关闭

站长推荐上一条 /1 下一条

QQ|侵权投诉|广告报价|手机版|小黑屋|西部数码代理|飘仙建站论坛 ( 豫ICP备2022021143号-1 )

GMT+8, 2025-1-31 10:34 , Processed in 0.044609 second(s), 9 queries , Redis On.

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

快速回复 返回顶部 返回列表