Woocommerce 分類下的產品如何使用ID號來作為默認排序字段


在給一個客戶開發網店系統時使用了WordPress系統的Woocommerce插件

WordPress版本:3.8
Woocommerce版本:2.0.20
如果沒有指定排序規則(指定的字段),則 Woocommerce默認使用的是" post_title"來排序的,但我在 調用分類下的產品時使用" ID"字段來自定義排序規則,但實際上卻並未按照自定義的規則來排序,而是使用” ORDER BY menu_order,post_title ASC“ 來排序 (在 product_category方法里沒有對ID進行排序處理)
 
Woocommerce 插件幫助里找到了自定義規則但還是沒有解決
 

 
在Google上搜索了半天也沒有找到解決辦法,於是轉而去看源碼解決,於是在\wp-content\plugins\woocommerce\classes\class-wc-shortcodes.php里找到product_category方法的定義並輸出排序信息
 
 
前台生成的Sql語句
 
 
在前台發現輸出的排序規則跟我自定義的規則並不一樣,接着繼續查看\wp-content\plugins\woocommerce\classes\class-wc-query.php里的get_catalog_ordering_args方法
 
 
 
原來 get_catalog_ordering_args方法在對排序時又進行了處理,所以不符合以上規則的該方法會重新設置排序規則,還好該方法提供了一個" woocommerce_get_catalog_ordering_args"filter
於是在funciton里重新定義" woocommerce_get_catalog_ordering_args"並返回我自定義的排序規則總算可以按照ID來排序了,將下面的代碼添加到主題的function里
add_filter( 'woocommerce_get_catalog_ordering_args', 'htl_woocommerce_get_catalog_ordering_args' );
/**
 * htl add 2014-10-28
 * 自定義分類下的產品排序規則
 * 該規則將會重置product_category方法里的排序字段
 * @param  [type] $args [排序數組]
 * @return [type]       [description]
 */
function htl_woocommerce_get_catalog_ordering_args( $args ) {
     $args['orderby']  = 'ID'; 
     //echo "<br>";
     //printer_r($args);
    return $args;
}

 

下面是前台頁面打印的Sql語句
 

 
至此就解決Woocommerce默認使用ID來排序分類下的產品,但有一個問題是我如果按照" menu_order" 先降序然后再按照ID來降序這種通過多個字段來進行排序的話好像不行
在WordPress-> WP_Query類里好像不能按照多個字段來排序( Woocommerce最后是調用 WP_Query來獲取數據的 ), 如果出現多個排序字段, WP_Query默認使用" post_date"來排序
后來通過 solagirl 知道wp4.0以后的版本已經支持多個排序字段了,但4.0以下版本不行,看來只能通過類似$wpdb這種方式來自己寫Sql進行排序了
 
 參考:
               WordPress WP_Query方法
               自定義WordPress查詢的4種方法
 
            


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM