在Woocommerce中显示最终缺货产品

时间:2014-08-04 07:21:42

标签: php wordpress woocommerce

是否可以在wordpress的类别或页面末尾显示缺货产品?

因此,客户首先会看到可用的产品,之后会看到缺货的产品。

9 个答案:

答案 0 :(得分:11)

这与Viktor&波格丹的答案,但没有额外的班级代码。

它使用post_clause过滤器来修改产品查询。我们JOIN查询的wp_postmeta表,并在现有查询前加上orderby _stock_status子句。这样,任何其他orderby子句也会保留在查询中。

add_filter('posts_clauses', 'order_by_stock_status');
function order_by_stock_status($posts_clauses) {
    global $wpdb;
    // only change query on WooCommerce loops
    if (is_woocommerce() && (is_shop() || is_product_category() || is_product_tag() || is_product_taxonomy())) {
        $posts_clauses['join'] .= " INNER JOIN $wpdb->postmeta istockstatus ON ($wpdb->posts.ID = istockstatus.post_id) ";
        $posts_clauses['orderby'] = " istockstatus.meta_value ASC, " . $posts_clauses['orderby'];
        $posts_clauses['where'] = " AND istockstatus.meta_key = '_stock_status' AND istockstatus.meta_value <> '' " . $posts_clauses['where'];
    }
    return $posts_clauses;
}

如果您出于某种原因首先想要缺货商品,则可以将istockstatus.meta_value ASC更改为istockstatus.meta_value DESC

在WP:4.8上测试; WC 3.0.8

答案 1 :(得分:3)

访问WooCommerce中库存管理的全局配置选项,查看WordPress管理员的左侧并单击WooCommerce,然后单击“设置”,然后单击“库存”选项卡。

你会发现这个&#34;缺货可见性&#34;

缺货可见性 - 此复选框可让您确定是否要隐藏WooCommerce目录中的库存商品。

http://www.inmotionhosting.com/support/website/woocommerce/managing-inventory-in-woocommerce

为了让它们显示在类别的末尾,您可以使用pre_get_posts根据库存进行订购,但之后您将失去其他排序。

答案 2 :(得分:2)

以下是重新排列产品的片段(现货供应):

<?php

/**
 * Order product collections by stock status, instock products first.
 */
class iWC_Orderby_Stock_Status
{

    public function __construct()
    {
        // Check if WooCommerce is active
        if (in_array('woocommerce/woocommerce.php', apply_filters('active_plugins', get_option('active_plugins')))) {
            add_filter('posts_clauses', array($this, 'order_by_stock_status'), 2000);
        }
    }

    public function order_by_stock_status($posts_clauses)
    {
        global $wpdb;
        // only change query on WooCommerce loops
        if (is_woocommerce() && (is_shop() || is_product_category() || is_product_tag())) {
            $posts_clauses['join'] .= " INNER JOIN $wpdb->postmeta istockstatus ON ($wpdb->posts.ID = istockstatus.post_id) ";
            $posts_clauses['orderby'] = " istockstatus.meta_value ASC, " . $posts_clauses['orderby'];
            $posts_clauses['where'] = " AND istockstatus.meta_key = '_stock_status' AND istockstatus.meta_value <> '' " . $posts_clauses['where'];
        }
        return $posts_clauses;
    }
}

new iWC_Orderby_Stock_Status;

?>

https://www.snip2code.com/Snippet/114858/WooCommerce-Products-Order-by-Stock-Stat

答案 3 :(得分:1)

此代码适用于我:

add_action( 'pre_get_posts', function( $query ) {
if ( $query->is_main_query() && is_woocommerce() && ( is_shop() || is_product_category() || is_product_tag() ) ) {
    if( $query->get( 'orderby' ) == 'menu_order title' ) {  // only change default sorting
        $query->set( 'orderby', 'meta_value' );
        $query->set( 'order', 'ASC' );
        $query->set( 'meta_key', '_stock_status' );
    }
}

});

答案 4 :(得分:1)

这是最好的解决方案:

add_action( 'pre_get_posts', function ( $q ) {
if (   !is_admin()                 // Target only front end 
     && $q->is_main_query()        // Only target the main query
     && $q->is_post_type_archive() // Change to suite your needs
) {
    $q->set( 'meta_key', '_stock_status' );
    $q->set( 'orderby',  'meta_value'    );
    $q->set( 'order',    'ASC'           );
}

},PHP_INT_MAX);

答案 5 :(得分:1)

我尝试了上述所有解决方案,它们均起作用,但导致网站上出现其他问题(可能是由于主题冲突),请确保它们在不同情况/主题下都很好。下面的代码终于对我有用(提到了源代码)

来源:https://www.businessbloomer.com/woocommerce-show-in-stock-products-first-shop/

/**
 * @snippet       Sort Products By Stock Status - WooCommerce Shop
 * @how-to        Get CustomizeWoo.com FREE
 * @author        Rodolfo Melogli
 * @compatible    WooCommerce 3.9
 * @donate $9     https://businessbloomer.com/bloomer-armada/
 */
 
add_filter( 'woocommerce_get_catalog_ordering_args', 'bbloomer_first_sort_by_stock_amount', 9999 );
 
function bbloomer_first_sort_by_stock_amount( $args ) {
   $args['orderby'] = 'meta_value';
   $args['order'] = 'ASC';
   $args['meta_key'] = '_stock_status';
   return $args;
}

答案 6 :(得分:0)

尝试使用此代码(放入主题的 functions.php ):

class iWC_Orderby_Stock_Status {
public function __construct() {
    if (in_array('woocommerce/woocommerce.php', apply_filters('active_plugins', get_option('active_plugins')))) {
        add_filter('posts_clauses', array($this, 'order_by_stock_status'), 2000);
    }
}
public function order_by_stock_status($posts_clauses) {
    global $wpdb;   
    if (is_woocommerce() && (is_shop() || is_product_category() || is_product_tag())) {
        $posts_clauses['join'] .= " INNER JOIN $wpdb->postmeta istockstatus ON ($wpdb->posts.ID = istockstatus.post_id) ";
        $posts_clauses['orderby'] = " istockstatus.meta_value ASC, " . $posts_clauses['orderby'];
        $posts_clauses['where'] = " AND istockstatus.meta_key = '_stock_status' AND istockstatus.meta_value <> '' " . $posts_clauses['where'];
    }
    return $posts_clauses;
    }
}
new iWC_Orderby_Stock_Status;

采取here

对于WooCommerce的最新版本,请参阅以下答案:https://stackoverflow.com/a/44597448/3925099

答案 7 :(得分:0)

上面编辑了一个答案:

/**
 * @snippet     Order product collections by stock status, instock products first.
 * @author      Rkoms
 */

class iWC_Orderby_Stock_Status {

    public function __construct() {
        if (in_array('woocommerce/woocommerce.php', apply_filters('active_plugins', get_option('active_plugins')))) {
            add_filter('posts_clauses', array($this, 'order_by_stock_status'), 2000, 2);
        }
    }

    public function order_by_stock_status($posts_clauses, $query) {
        global $wpdb;   
        if ( $query->is_main_query() && is_woocommerce() && (is_shop() || is_product_category() || is_product_tag())) {
            $posts_clauses['join'] .= " INNER JOIN $wpdb->postmeta istockstatus ON ($wpdb->posts.ID = istockstatus.post_id) ";
            $posts_clauses['orderby'] = " istockstatus.meta_value ASC, " . $posts_clauses['orderby'];
            $posts_clauses['where'] = " AND istockstatus.meta_key = '_stock_status' AND istockstatus.meta_value <> '' " . $posts_clauses['where'];
        }
        return $posts_clauses;
    }

}
new iWC_Orderby_Stock_Status;

答案 8 :(得分:0)

@dacrosby 的答案真的应该是这里的最佳答案。我在与某些插件的兼容性方面遇到了一些问题,但在大多数用例中,它似乎完全没有问题。

这里说的是一些警告

  • 以编程方式创建产品的插件有时无法添加库存状态元键,如果此键不存在,此解决方案会将它们从结果中完全过滤掉。
  • 在某些用例中,此解决方案可能会与现有排序发生冲突,因为我们根据 stockstatus 值按字母顺序排序。如果使用了多种库存状态类型,则会根据这种排序在结果中人为地对它们进行分组。

这个版本建立在相同的实现之上,应该提供更广泛的兼容性,而不会牺牲预期的结果。


/**
 * Sorts the Woocommerce Archive product query to push out of stock products to the end 
 */
function _nok_order_by_stock_status( $posts_clauses, $query ) {

    // only change query on WooCommerce loops
    if ( $query->is_main_query() && ( is_product_category() || is_product_tag() || is_product_taxonomy() || is_shop() ) ) {
        global $wpdb;

        $posts_clauses['join'] .= 
        " LEFT JOIN ( 
            SELECT post_id, meta_id, meta_value FROM $wpdb->postmeta 
            WHERE meta_key = '_stock_status' AND meta_value <> '' 
        ) istockstatus ON ($wpdb->posts.ID = istockstatus.post_id) ";

        $posts_clauses['orderby'] = 
        " CASE istockstatus.meta_value WHEN 
            'outofstock' THEN 1 
            ELSE 0 
        END ASC, " . $posts_clauses['orderby'];
    }

    return $posts_clauses;
}
add_filter( 'posts_clauses', '_nok_order_by_stock_status', 2000, 2 );

相关问题