我正在尝试创建一个为可变产品设置缩略图的函数。此刻,我将不得不进入后端并手动应用图像,但是我想要更动态的东西。
例如,假设我有一个名为Lamp的变量产品,里面有三个子产品。每个子产品都是相同的,但颜色不同(蓝色,绿色,黄色)。现在,我想要的是变量产品具有与内部第一个版本相同的图像,但是如果将黄色滤色器应用于商店页面,我想获取该版本的图像并显示为可变缩略图。
我几乎已经创建了此功能,但是如果声明适用于不同的产品,并且最终为该产品提供多个缩略图,则会出现一个问题。
如何改善此功能?
remove_action( 'woocommerce_before_shop_loop_item_title', 'woocommerce_template_loop_product_thumbnail', 10);
add_action( 'woocommerce_before_shop_loop_item_title', 'set_product_image', 10);
function set_product_image() {
global $product;
if( $product->is_type('variable') ){
foreach ( $product->get_visible_children() as $variation_id ){
$variation = wc_get_product( $variation_id );
$product_colour = strtolower( $variation->get_attribute('colour') );
$filter_colour = $_GET['filter_colour'];
if( $product_colour == $filter_colour){
echo $variation->get_image( array(300, 300) );
}else if( $product_colour != $filter_colour ){
// echo $variation->get_image( array(300, 300) );
}
}
}else if( $product->is_type('simple') ){
if ( has_post_thumbnail() ) {
echo $product->get_image( array(300, 300) );
}
}
}
答案 0 :(得分:1)
尝试以下代码:
if( $product->is_type('variable') ){
// image of first variation
$default_image = '';
foreach ( $product->get_visible_children() as $variation_id ){
$variation = wc_get_product( $variation_id );
$product_colour = strtolower( $variation->get_attribute('colour') );
// set image of first variation
if( $default_image == '' ){
$default_image = $variation->get_image( array(300, 300) );
}
$filter_colour = $_GET['filter_colour'];
if( $product_colour == $filter_colour){
// if filter applied, echo and return
echo $variation->get_image( array(300, 300) );
return;
}
}
// filter not applied, return default image
echo $default_image ;
}