織夢cms利用weight排序無效的解決方案_PHP教程

來源:互聯網
上載者:User
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/]
{/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/]
{/dede:arclist}

http://www.bkjia.com/PHPjc/632148.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/632148.htmlTechArticlededecms5.7針對weight排序是有bug的,下面我來一步步告訴大家如何解決weight無效的解決辦法,具體請參考下面。 涉及的檔案是includetaglibarclist.l...

  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.