wordpress WooCommerce中的多个订单

xzlaal3s  于 2023-11-17  发布在  WordPress
关注(0)|答案(2)|浏览(191)

我想订购我的产品在类别页面的平均评级(DESC),然后按价格(ASC)。

  1. | id | avgrating | price |
  2. | 1 | 4 | 10 |
  3. | 2 | 4 | 5 |
  4. | 3 | 5 | 7 |

字符串
顺序:三,二,一。
所以我试着:

  1. $args['meta_key'] = '_wc_average_rating';
  2. $args['orderby'] = array(
  3. 'meta_value_num' => 'DESC',
  4. 'price' => 'ASC',
  5. );


但是它们不是按价格排序的。我也用_price替换了price,结果一样。
我使用的是最新版本的WordPress(4.8)和WooCommerce(3.0.8)。

编辑:

如果我用途:

  1. $args['meta_key'] = '_wc_average_rating';
  2. $args['orderby'] = array(
  3. 'meta_value_num' => 'DESC',
  4. 'ID' => 'DESC',
  5. );


顺序工程作为例外,DESC的平均评级,然后DESC的ID。所以,我必须改变IDprice,但我不能使它工作。

xa9qqrwz

xa9qqrwz1#

通过传递带有参数的order进行检查
看看这些

  1. add_filter( 'woocommerce_get_catalog_ordering_args', 'custom_woocommerce_get_catalog_ordering_args' );
  2. function custom_woocommerce_get_catalog_ordering_args( $args ) {
  3. $orderby_value = isset( $_GET['orderby'] ) ? woocommerce_clean( $_GET['orderby'] ) : apply_filters( 'woocommerce_default_catalog_orderby', get_option( 'woocommerce_default_catalog_orderby' ) );
  4. if ( 'sort_by_type' == $orderby_value ) {
  5. $args['orderby'] = 'meta_value_num title';
  6. $args['order'] = 'ASC';
  7. $args['meta_key'] = 'sort_by_type';
  8. }
  9. if ( '_wc_average_rating' == $orderby_value ) {
  10. $args['orderby'] = 'meta_value_num title';
  11. $args['order'] = 'DESC';
  12. $args['meta_key'] = '_wc_average_rating';
  13. }
  14. return $args;
  15. }

字符串

展开查看全部
shstlldc

shstlldc2#

我想订购的产品首先由日期然后缺货的项目是在年底。我尝试了下面的代码。但不工作。

  1. add_filter( 'woocommerce_get_catalog_ordering_args', 'custom_woocommerce_get_catalog_ordering_args' );
  2. function custom_woocommerce_get_catalog_ordering_args( $args ) {
  3. $orderby_value = isset( $_GET['orderby'] ) ? woocommerce_clean( $_GET['orderby'] ) : apply_filters( 'woocommerce_default_catalog_orderby', get_option( 'woocommerce_default_catalog_orderby' ) );
  4. if ( 'sort_by_date' == $orderby_value ) {
  5. $args['orderby'] = 'meta_value';
  6. $args['order'] = 'ASC';
  7. $args['meta_key'] = 'sort_by_date';
  8. }
  9. if ( '_stock_status' == $orderby_value ) {
  10. $args['orderby'] = 'meta_value';
  11. $args['order'] = 'DESC';
  12. $args['meta_key'] = '_stock_status';
  13. }
  14. return $args;
  15. }

字符串

展开查看全部

相关问题