簡體   English   中英

Woocommerce /如何按庫存狀態分類相關產品?

[英]Woocommerce / how to sort related products by stock status?

如何在woocommerce中按庫存狀態對相關產品進行排序?
我已將此代碼添加到function.php

function custom_remove_hook(){
    remove_action( 'woocommerce_after_single_product_summary', 'woocommerce_output_related_products', 20 );
    add_action( 'woocommerce_after_single_product_summary', 'custom_function_to_sort_related', 22 );
}
add_action( 'woocommerce_after_single_product_summary', 'custom_remove_hook' );

function custom_function_to_sort_related( $args = array() ) {
    global $product;

    if ( ! $product ) {
        return;
    }

    $defaults = array(
        'posts_per_page' => 4,
        'columns'        => 4,
        'orderby'        => 'price', // @codingStandardsIgnoreLine.
        'order'          => 'desc'
    );

    $args = wp_parse_args( $args, $defaults );

    // Get visible related products then sort them at random.
    $args['related_products'] = array_filter( array_map( 'wc_get_product', wc_get_related_products( $product->get_id(), $args['posts_per_page'], $product->get_upsell_ids() ) ), 'wc_products_array_filter_visible' );

    // Handle orderby.
    $args['related_products'] = wc_products_array_orderby( $args['related_products'], $args['orderby'], $args['order'] );

    // Set global loop values.
    wc_set_loop_prop( 'name', 'related' );
    wc_set_loop_prop( 'columns', apply_filters( 'woocommerce_related_products_columns', $args['columns'] ) );

    wc_get_template( 'single-product/related.php', $args );
}


但是我想按庫存狀態在單頁中對相關產品進行排序(首先顯示庫存產品,然后顯示缺貨產品);
我已經更改了$defaults數組,如下所示:

$defaults = array(
        'posts_per_page' => 4,
        'columns'        => 4,
        'orderby'        => '_stock_status', 
        'order'          => 'array( 'meta_value' => 'ASC' )
    );

沒用 我怎么解決這個問題?

嘗試這些而不是您曾經使用過的

$defaults = array(
            'posts_per_page' => 4,
            'columns'        => 4,
            'orderby'        => array('price', 'stock')
            'order'          => 'desc'
        );

或者,您也可以根據需要對過濾的圖像進行排序,同時從數據庫中獲取圖像。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM