国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > CMS > 織夢DEDE > 正文

織夢dedecms使用ARCLIST標簽中IDLIST進行文章排序

2024-07-12 09:12:03
字體:
來源:轉載
供稿:網友
排序總是一個頭痛的問題,織夢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或使用緩存中的idif($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$addfieldsSqlFROM `$maintable` arc left join `dede_arctype` tp on arc.typeid=tp.id$addfieldsSqlJoinWHERE 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排序了

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 突泉县| 庆云县| 伽师县| 辽阳市| 肇州县| 甘德县| 巴楚县| 勐海县| 新闻| 凌源市| 高邮市| 赤壁市| 宜川县| 藁城市| 西城区| 金平| 台北市| 安宁市| 泉州市| 太仆寺旗| 通州区| 汝城县| 丰顺县| 阿拉善左旗| 扎兰屯市| 阿勒泰市| 定陶县| 昭通市| 德格县| 宁夏| 崇明县| 松潘县| 云龙县| 扶绥县| 郧西县| 江油市| 和平区| 海安县| 霸州市| 宜兴市| 万安县|