加入vip [簽到送金幣]
注冊 登錄 QQ登錄
織夢無憂,用心做好源碼!7年品牌,值得信賴! 織夢無憂,個個精品,寧缺毋濫!每月購買不少于3000元精品源碼免費分享,早開通,早享受!終身會員臨時大促,只需要498元!新會員開通,直接進入會員中心--購買會員--直接開通即可。

DEDECMS怎么使用ARCLIST標簽中IDLIST進行文章排序

摘要: 平時跟版網看見站長朋友們做站的時候,排序總是一個頭痛的問題,DedeCMS默認的文章排序功能已經非常強大了,但是唯一缺少的就是,按指定的id順序排序,跟版網小編經過左思右想,終于把這個問題解決了,DedeCMS默認的arclist標簽有一個idlist調用指定id的文章
平時跟版網看見站長朋友們做站的時候,排序總是一個頭痛的問題,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排序了

本文鏈接:http://www.jnzgi.cn//dedecmsjiaocheng/biaoqiandiaoyong/181698.html

版權聲明:本站資源均來自互聯網或會員發布,如果侵犯了您的權益請與我們聯系,我們將在24小時內刪除!謝謝!

公眾號二維碼

微信公眾號

//自動推送 一本久道综合在线中文无码-日韩人妻无码一区2区3区-44800青苹果高清影院免费
<蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <蜘蛛词>| <文本链> <文本链> <文本链> <文本链> <文本链> <文本链>