找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 137|回复: 0

[cms教程] 织梦dedecms使用ARCLIST标签中IDLIST进行文章排序

[复制链接]

该用户从未签到

发表于 2020-2-26 12:09:47 | 显示全部楼层 |阅读模式

您需要 登录 才可以下载或查看,没有账号?立即注册

×
排序总是一个头痛的问题,织梦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排序了
回复

使用道具 举报

网站地图|页面地图|文字地图|Archiver|手机版|小黑屋|找资源 |网站地图

GMT+8, 2024-11-27 21:32

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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