gpt4 book ai didi

wordpress - 如何使用产品 ID 隐藏产品简码 'woocommerce_shortcode_products_query' 中的产品

转载 作者:行者123 更新时间:2023-12-05 03:29:39 25 4
gpt4 key购买 nike

我正在使用 woocommerce 产品短代码在产品页面上显示一些相关产品。

产品简码如下:

do_shortcode('[products limit="6" columns="6"]');

我正在使用 woocommerce_shortcode_products_query 过滤器修改简码,如下所示:

add_filter( 'woocommerce_shortcode_products_query', function( $query_args, $atts, $loop ){

$product_id = 12345;

// Remove out of stock results
$query_args['meta_query'] = array( array(
'key' => '_stock_status',
'value' => 'outofstock',
'compare' => 'NOT LIKE',
) );

// Remove the current product by id
$query_args['tax_query'] = array( array(
'taxonomy' => 'product',
'field' => 'id',
'terms' => array($product_id), // Remove this product from the shortcode results
'operator' => 'NOT IN',
) );



return $query_args;

}, 10, 3);

第一部分通过删除缺货结果来工作。

第二部分不起作用,我无法弄清楚如何从查询中排除特定产品。

搜索问题时来自谷歌的所有结果都在谈论 product_cat 分类法,但是我不想删除类别中的产品,我想删除当前产品 by id 这样只有其他相关产品显示在简码中。

所以我的问题是:如何使用“woocommerce_shortcode_products_query”从产品简码中隐藏当前产品

最佳答案

您需要使用 WP_Query'post__not_in' 参数.

所以你的代码应该是这样的:

add_filter('woocommerce_shortcode_products_query', function ($query_args, $atts, $loop) {

$product_ids = array(1, 2, 3);

$query_args['meta_query'] = array(array(
'key' => '_stock_status',
'value' => 'outofstock',
'compare' => 'NOT LIKE',
));

$query_args['post__not_in'] = $product_ids;


return $query_args;
}, 10, 3);

这将排除 ID 为 123 的产品。您可以将不同的产品 ID 传递给 $product_ids 变量。

您也可以只排除一种产品,只需将一个 ID 传递给 $product_ids 变量即可! (例如 $product_ids = array(37))

关于wordpress - 如何使用产品 ID 隐藏产品简码 'woocommerce_shortcode_products_query' 中的产品,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/70999306/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com