WooCommerce可变产品的动态缩略图

时间:2018-08-29 13:39:25

标签: php wordpress woocommerce

我正在尝试创建一个为可变产品设置缩略图的函数。此刻,我将不得不进入后端并手动应用图像,但是我想要更动态的东西。

例如,假设我有一个名为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) );
        }
    }
}

1 个答案:

答案 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 ;
}