gpt4 book ai didi

php - WooCommerce - 自定义缩略图和默认后备图像占位符

转载 作者:塔克拉玛干 更新时间:2023-11-03 06:04:48 24 4
gpt4 key购买 nike

我只想向 woocommerce_get_product_thumbnail 插入一个包装器,我可以看到我的包装器出现了,但如果没有图像,它就没有后备图像。

如何输出默认的 woocommerce 缩略图?

这是我的不完整代码:

remove_action( 'woocommerce_before_shop_loop_item_title', 'woocommerce_template_loop_product_thumbnail', 10);
add_action( 'woocommerce_before_shop_loop_item_title', 'woocommerce_template_loop_product_thumbnail', 10);

if ( ! function_exists( 'woocommerce_template_loop_product_thumbnail' ) ) {
function woocommerce_template_loop_product_thumbnail() {
echo woocommerce_get_product_thumbnail();
}
}
if ( ! function_exists( 'woocommerce_get_product_thumbnail' ) ) {
function woocommerce_get_product_thumbnail( $size = 'shop_catalog', $placeholder_width = 0, $placeholder_height = 0 ) {
global $post, $woocommerce;
$output = '<div class="col-lg-4">';

if ( has_post_thumbnail() ) {
$output .= get_the_post_thumbnail( $post->ID, $size );
} else {
how to show the default woocommerce thumb
}
$output .= '</div>';
return $output;
}
}

最佳答案

我在开始时为 remove_actionadd_action 添加了一个 init Hook ,以便在 WordPress/WooCommerce 初始化时触发它......

由于 $placeholder_width = 0, $placeholder_height = 0 自 woocommerce 版本 2.0 ( see this ) 以来已弃用。您不再需要它们,这可能是您问题的一部分。

注:pallavi的答案对于 $output .= wc_placeholder_img( $size ); 在您的 else 语句中是正确的。我已经为此投票给他......

所以我对你的代码做了一点改动:

add_action('init', function(){
remove_action( 'woocommerce_before_shop_loop_item_title', 'woocommerce_template_loop_product_thumbnail', 10);
add_action( 'woocommerce_before_shop_loop_item_title', 'woocommerce_template_loop_product_thumbnail', 10);
});

if ( ! function_exists( 'woocommerce_template_loop_product_thumbnail' ) ) {
function woocommerce_template_loop_product_thumbnail() {
echo woocommerce_get_product_thumbnail();
}
}

if ( ! function_exists( 'woocommerce_get_product_thumbnail' ) ) {
function woocommerce_get_product_thumbnail( $size = 'shop_catalog' ) {
global $post, $woocommerce;
$output = '<div class="col-lg-4">';

if ( has_post_thumbnail() ) {
$output .= get_the_post_thumbnail( $post->ID, $size );
} else {
$output .= wc_placeholder_img( $size );
// Or alternatively setting yours width and height shop_catalog dimensions.
// $output .= '<img src="' . woocommerce_placeholder_img_src() . '" alt="Placeholder" width="300px" height="300px" />';
}
$output .= '</div>';
return $output;
}
}

关于php - WooCommerce - 自定义缩略图和默认后备图像占位符,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38320744/

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