dedecms5.7針對weight排序是有bug的,下面我來一步步告訴大家如何解決weight無效的解決辦法,具體請參考下面。
涉及的文件是includetaglibarclist.lib.php文件:
第570行左右:
代碼如下 復制代碼 if ( $isweight==’y’ )這一行代碼簡直是廢柴,$orderWeight = list_sort_by($orderWeight, ‘weight’, ‘asc’); 對結果進行排序。
這個是有問題的,因為在得到這個$orderWeight之前,檢索文檔表的語句為:
代碼如下 復制代碼SELECT arc.*,tp.typedir,tp.typename,tp.corank,tp.isdefault,tp.defaultname,tp.namerule,
tp.namerule2,tp.ispart,tp.moresite,tp.siteurl,tp.sitepath
FROM `dede_archives` arc LEFT JOIN `dede_arctype` tp ON arc.typeid=tp.id WHERE arc.typeid IN (29) AND
arc.arcrank > -1 ORDER BY arc.sortrank DESC
很明顯了吧,我們在寫標簽的時候,寫的是
代碼如下 復制代碼{dede:arclist orderby=’weight’ typeid=’29′ isweight=’y’
limit=’4,1′ titlelen=’100′ infolen=’100′ }
,本意是數據按照weight進行排序,二處理程序是按照
sortrank 檢索的數據庫,指定 isweight=’y’ 僅僅是起到了將檢索出的數據集再根據weight排序。
所以處理辦法非常簡單:在該程序文件330行處,增加一行按照weight排序的處理語句:
else if($orderby ==
‘weight’) $ordersql = ” order by arc.weight asc”;
我們再分離一個讓list標簽支持weight排序
代碼如下 復制代碼{dede:list pagesize='10' titlelen='50' orderby='weight'} •[field:textlink/]<br/> {/dede:list}
辦法:
1、打開文件arc.listview.class.php
2、查找“else if($orderby=="lastpost") {” 語句,大概在609行,在此行前面按下回車健,插入如下語句:
代碼如下 復制代碼else if($orderby=="weight") { $ordersql = " order by arc.weight $orderWay"; }
3、繼續查找“if(ereg('hot|click|lastpost',$orderby))”語句,修改為:
代碼如下 復制代碼if(ereg('hot|click|weight|lastpost',$orderby))
修改完成後,保存,如果目標裡面已經使用了weight排序,生成一下,就可以看到,文檔列表已經安裝weight排序
4、模板調用
代碼如下 復制代碼{dede:arclist row='10' titlelen='50' orderby='weight'} •[field:textlink/]<br/> {/dede:arclist}