0

0

如何在 WooCommerce 商品列表页显示首个产品分类的缩略图徽章

心靈之曲

心靈之曲

发布时间:2026-02-02 23:20:03

|

299人浏览过

|

来源于php中文网

原创

如何在 WooCommerce 商品列表页显示首个产品分类的缩略图徽章

本文介绍如何在 woocommerce 商品循环(shop loop)中,为每个商品自动显示其所属首个产品分类的自定义缩略图徽章,兼容现代 woocommerce 版本,支持响应式图片属性与占位图回退。

在 WooCommerce 商城中,常需通过视觉化方式快速传达商品归属(如品牌、系列或品类),例如在商品卡片顶部展示“Sunglasses”分类的专属图标徽章。原始代码存在多个问题:错误使用已废弃的 get_woocommerce_term_meta()、未适配新版 WooCommerce 的 WP_Query 上下文($product 对象更可靠)、逻辑混淆(误判 is_product() 导致钩子在目录页失效)、且未处理无缩略图时的降级方案。

以下为优化后的专业实现方案:

✅ 正确钩子与上下文

使用 woocommerce_before_shop_loop_item_title 钩子(优先级 20,避免与其他插件冲突),并在函数内直接调用 $product->get_id() 获取当前商品 ID —— 这比依赖全局 $post 更健壮,尤其在 AJAX 或自定义查询场景下。

✅ 获取首个有效分类并读取缩略图

add_action('woocommerce_before_shop_loop_item_title', 'display_product_category_thumbnail', 20);
function display_product_category_thumbnail() {
    global $product;

    // 获取商品所属的第一个 product_cat 分类(跳过空值)
    $terms = get_the_terms($product->get_id(), 'product_cat');
    $productFirstCategory = $terms && ! is_wp_error($terms) ? reset($terms) : null;

    if ( ! $productFirstCategory ) {
        return;
    }

    // 定义缩略图尺寸(复用 WooCommerce 内置尺寸)
    $small_thumb_size = 'woocommerce_thumbnail';
    $dimensions = wc_get_image_size($small_thumb_size);

    // 读取分类元数据中的 thumbnail_id(新版推荐用 get_term_meta)
    $thumbnail_id = get_term_meta($productFirstCategory->term_id, 'thumbnail_id', true);

    if ($thumbnail_id && wp_get_attachment_image_src($thumbnail_id, $small_thumb_size)) {
        $image_data = wp_get_attachment_image_src($thumbnail_id, $small_thumb_size);
        $image = is_array($image_data) ? $image_data[0] : '';
        $srcset = function_exists('wp_get_attachment_image_srcset') 
            ? wp_get_attachment_image_srcset($thumbnail_id, $small_thumb_size) 
            : '';
        $sizes = function_exists('wp_get_attachment_image_sizes') 
            ? wp_get_attachment_image_sizes($thumbnail_id, $small_thumb_size) 
            : '(max-width: 350px) 100vw, 350px';
    } else {
        // 回退至 WooCommerce 占位图
        $image = wc_placeholder_img_src();
        $srcset = $sizes = '';
    }

    // 输出语义化徽章容器(建议配合 CSS 控制尺寸与定位)
    if ($image) {
        echo '';
    }
}

⚠️ 注意事项与最佳实践

  • 分类缩略图设置:确保已在 WordPress 后台 → 产品 → 分类中,为对应分类上传并保存「分类图像」(该操作会自动写入 thumbnail_id 元字段);
  • CSS 样式建议:.brand-icon-logo { position: absolute; top: 12px; left: 12px; z-index: 2; } 配合 position: relative 的商品容器;
  • 性能优化:已启用 loading="lazy" 和响应式 srcset/sizes,适配移动端;
  • 多分类场景说明:本方案默认取首个分类(最常用场景);若需匹配特定父分类(如仅显示 sunglasses 下的子类),可扩展条件判断,例如:
    if ($productFirstCategory->parent === get_term_by('slug', 'sunglasses', 'product_cat')->term_id)

此实现简洁、健壮、可维护,适用于 WooCommerce 6.0+ 及主流主题(如 Storefront、Astra),是展示品类身份标识的专业级解决方案。

' . esc_attr($productFirstCategory->

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
ajax教程
ajax教程

php中文网为大家带来ajax教程合集,Ajax是一种用于创建快速动态网页的技术。通过在后台与服务器进行少量数据交换,Ajax可以使网页实现异步更新。这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新。php中文网还为大家带来ajax的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

160

2023.06.14

ajax中文乱码解决方法
ajax中文乱码解决方法

ajax中文乱码解决方法有设置请求头部的字符编码、在服务器端设置响应头部的字符编码和使用encodeURIComponent对中文进行编码。本专题为大家提供ajax中文乱码相关的文章、下载、课程内容,供大家免费下载体验。

160

2023.08.31

ajax传递中文乱码怎么办
ajax传递中文乱码怎么办

ajax传递中文乱码的解决办法:1、设置统一的编码方式;2、服务器端编码;3、客户端解码;4、设置HTTP响应头;5、使用JSON格式。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

117

2023.11.15

ajax网站有哪些
ajax网站有哪些

使用ajax的网站有谷歌、维基百科、脸书、纽约时报、亚马逊、stackoverflow、twitter、hacker news、shopify和basecamp等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

237

2024.09.24

ajax教程
ajax教程

php中文网为大家带来ajax教程合集,Ajax是一种用于创建快速动态网页的技术。通过在后台与服务器进行少量数据交换,Ajax可以使网页实现异步更新。这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新。php中文网还为大家带来ajax的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

160

2023.06.14

ajax中文乱码解决方法
ajax中文乱码解决方法

ajax中文乱码解决方法有设置请求头部的字符编码、在服务器端设置响应头部的字符编码和使用encodeURIComponent对中文进行编码。本专题为大家提供ajax中文乱码相关的文章、下载、课程内容,供大家免费下载体验。

160

2023.08.31

ajax传递中文乱码怎么办
ajax传递中文乱码怎么办

ajax传递中文乱码的解决办法:1、设置统一的编码方式;2、服务器端编码;3、客户端解码;4、设置HTTP响应头;5、使用JSON格式。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

117

2023.11.15

ajax网站有哪些
ajax网站有哪些

使用ajax的网站有谷歌、维基百科、脸书、纽约时报、亚马逊、stackoverflow、twitter、hacker news、shopify和basecamp等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

237

2024.09.24

AO3官网入口与中文阅读设置 AO3网页版使用与访问
AO3官网入口与中文阅读设置 AO3网页版使用与访问

本专题围绕 Archive of Our Own(AO3)官网入口展开,系统整理 AO3 最新可用官网地址、网页版访问方式、正确打开链接的方法,并详细讲解 AO3 中文界面设置、阅读语言切换及基础使用流程,帮助用户稳定访问 AO3 官网,高效完成中文阅读与作品浏览。

89

2026.02.02

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.8万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.2万人学习

CSS教程
CSS教程

共754课时 | 26.6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号