在 WooCommerce WC_Product_Query 中按产品属性条款过滤
Filter by product attribute terms in a WooCommerce WC_Product_Query
我正在尝试使用 WC_Product_Query 为产品创建循环。
现在我想按产品属性过滤它们。
使用 WP Query 可以做到这一点,使用 tax_query。
但是使用 WC_Product_Query 它不起作用。
(我不想要 WP_Query
,因为对于产品来说最好使用 WC_Product_Query
)
<?php
$query = new WC_Product_Query(array(
'limit' => 5,
'orderby' => 'date',
'order' => 'DESC',
));
$products = $query->get_products();
$products = wc_products_array_orderby( $products, 'price', 'DESC' );
if (!empty($products)) :
?>
<table>
<?php
foreach ($products as $product) :
?>
<tr>
<td><a href="<?php echo get_permalink($product->get_id()); ?>"><?php echo get_the_title($product->get_id()); ?></a></td>
<td><?php echo get_the_post_thumbnail( $product->get_id(), 'thumbnail' ); ?></td>
<td><?php echo $product->get_price(); ?></td>
</tr>
<?php
endforeach;
?>
</table>
<?php
endif;
以下是在 WP 查询中的操作方法:
$args = array(
'post_type' => 'product',
'tax_query' => array(
array(
'taxonomy' => 'pa_color',
'field' => 'slug',
'terms' => 'red',
),
),
);
$query = new WP_Query( $args );
就像在 WP_Query
中一样,您可以在 WC_Product_Query
中使用 tax_query
,例如:
$query = new WC_Product_Query(array(
'limit' => 5,
'orderby' => 'date',
'order' => 'DESC',
'tax_query' => array( array(
'taxonomy' => 'pa_color',
'field' => 'slug',
'terms' => 'red',
) ),
) );
$products = wc_products_array_orderby( $query->get_products(), 'price', 'DESC' );
if ( ! empty($products) ) : ?>
<table><?php
// Products loop
foreach ($products as $product) : ?>
<tr>
<td><a href="<?php echo get_permalink($product->get_id()); ?>"><?php echo get_the_title($product->get_id()); ?></a></td>
<td><?php echo get_the_post_thumbnail( $product->get_id(), 'thumbnail' ); ?></td>
<td><?php echo $product->get_price(); ?></td>
</tr><?php
endforeach; ?>
</table><?php
endif;
从 WooCommerce 版本 3 开始测试并工作。
我正在尝试使用 WC_Product_Query 为产品创建循环。
现在我想按产品属性过滤它们。
使用 WP Query 可以做到这一点,使用 tax_query。
但是使用 WC_Product_Query 它不起作用。
(我不想要 WP_Query
,因为对于产品来说最好使用 WC_Product_Query
)
<?php
$query = new WC_Product_Query(array(
'limit' => 5,
'orderby' => 'date',
'order' => 'DESC',
));
$products = $query->get_products();
$products = wc_products_array_orderby( $products, 'price', 'DESC' );
if (!empty($products)) :
?>
<table>
<?php
foreach ($products as $product) :
?>
<tr>
<td><a href="<?php echo get_permalink($product->get_id()); ?>"><?php echo get_the_title($product->get_id()); ?></a></td>
<td><?php echo get_the_post_thumbnail( $product->get_id(), 'thumbnail' ); ?></td>
<td><?php echo $product->get_price(); ?></td>
</tr>
<?php
endforeach;
?>
</table>
<?php
endif;
以下是在 WP 查询中的操作方法:
$args = array(
'post_type' => 'product',
'tax_query' => array(
array(
'taxonomy' => 'pa_color',
'field' => 'slug',
'terms' => 'red',
),
),
);
$query = new WP_Query( $args );
就像在 WP_Query
中一样,您可以在 WC_Product_Query
中使用 tax_query
,例如:
$query = new WC_Product_Query(array(
'limit' => 5,
'orderby' => 'date',
'order' => 'DESC',
'tax_query' => array( array(
'taxonomy' => 'pa_color',
'field' => 'slug',
'terms' => 'red',
) ),
) );
$products = wc_products_array_orderby( $query->get_products(), 'price', 'DESC' );
if ( ! empty($products) ) : ?>
<table><?php
// Products loop
foreach ($products as $product) : ?>
<tr>
<td><a href="<?php echo get_permalink($product->get_id()); ?>"><?php echo get_the_title($product->get_id()); ?></a></td>
<td><?php echo get_the_post_thumbnail( $product->get_id(), 'thumbnail' ); ?></td>
<td><?php echo $product->get_price(); ?></td>
</tr><?php
endforeach; ?>
</table><?php
endif;
从 WooCommerce 版本 3 开始测试并工作。