程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> 織夢cms利用weight排序無效的解決方法

織夢cms利用weight排序無效的解決方法

編輯:關於PHP編程

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}

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved