0

0

WooCommerce 购物车页面显示产品品牌指南:正确识别分类法

DDD

DDD

发布时间:2025-09-19 14:40:01

|

281人浏览过

|

来源于php中文网

原创

woocommerce 购物车页面显示产品品牌指南:正确识别分类法

在 WooCommerce 购物车页面显示产品品牌信息是提升用户体验的常见需求。然而,在尝试使用 wp_get_post_terms 函数获取品牌时,开发者常会遇到 invalid_taxonomy 错误。本文将深入解析此错误的原因,并提供两种有效方法来定位正确的产品品牌分类法(taxonomy)名称,最终指导您如何在购物车页面成功集成并展示产品品牌。

引言:在 WooCommerce 购物车页面显示产品品牌的需求

在电子商务网站中,品牌信息对于消费者而言具有重要的参考价值。在 WooCommerce 购物车页面清晰地展示产品品牌,不仅能增强用户对商品的信任感,也能帮助用户在结算前再次确认所选商品的具体信息。然而,直接在购物车模板中添加品牌信息时,许多开发者会遇到 wp_get_post_terms 函数返回 invalid_taxonomy 错误,导致品牌无法正常显示。

理解 invalid_taxonomy 错误

当您尝试使用 wp_get_post_terms() 函数来获取某个文章(或产品)的分类法(taxonomy)术语时,如果传入的分类法名称不正确或不存在,WordPress 就会返回一个 WP_Error 对象,其中包含 invalid_taxonomy 错误信息。

wp_get_post_terms($product_id, 'your_taxonomy_name', ['fields' => 'names'])

这个函数的核心在于第二个参数 'your_taxonomy_name'。它必须精确匹配您的品牌插件或主题所注册的自定义分类法名称。如果名称不匹配,WordPress 将无法识别该分类法,从而引发 invalid_taxonomy 错误。常见的错误尝试包括使用 pwb-brand 或 product_brand,但这些名称并非通用,它们取决于您使用的具体插件或主题。

定位正确的产品品牌分类法(Taxonomy)名称

解决 invalid_taxonomy 错误的关键在于找到您系统中实际使用的产品品牌分类法名称。以下是两种有效的方法:

方法一:通过 WordPress 后台 URL 查找(推荐)

这是最直接且通常最简单的方法。WordPress 在后台管理界面中,会将其分类法名称显示在编辑页面的 URL 中。

  1. 登录 WordPress 后台:使用管理员账户登录您的网站。
  2. 导航至品牌管理页面
    • 如果您的品牌是由插件(如 Perfect WooCommerce Brands)提供的,通常会在 WooCommerce 或产品菜单下找到“品牌”或“Brands”选项。
    • 点击进入该品牌管理页面,您会看到所有已创建的品牌列表。
  3. 检查浏览器地址栏 URL:在品牌管理页面的 URL 中,查找 taxonomy= 参数。该参数后面的值就是您要找的分类法名称。

示例 URL 解析:

假设您在浏览器地址栏中看到类似以下 URL:

https://yourwebsite.com/wp-admin/edit-tags.php?taxonomy=ourbrandname&post_type=product

在这个 URL 中,taxonomy=ourbrandname 部分明确指出了您的品牌分类法名称是 ourbrandname。

方法二:检查插件或主题代码(适用于开发者)

如果通过 URL 查找不便,或者您是开发者,可以直接检查您的品牌插件或主题的源代码:

  1. 查看品牌插件的 functions.php 或主文件:许多品牌插件会在其主文件或 includes 文件夹中的某个文件中注册自定义分类法。搜索 register_taxonomy 函数的调用,其第一个参数通常就是分类法名称。
  2. 查看主题的 functions.php 文件:如果品牌功能是由主题提供的,那么相关代码可能位于主题的 functions.php 文件中。

在购物车页面集成品牌信息

一旦您确定了正确的品牌分类法名称,就可以将其应用到 wp_get_post_terms 函数中,并在购物车页面显示品牌信息。

喜鹊标书
喜鹊标书

AI智能标书制作平台,10分钟智能生成20万字投标方案,大幅提升中标率!

下载

核心逻辑:

  1. 获取购物车项的产品 ID。
  2. 使用正确的分类法名称调用 wp_get_post_terms 获取品牌。
  3. 遍历品牌并显示其名称。

示例代码:在 cart.php 中添加品牌显示

为了在 WooCommerce 购物车页面显示品牌,您通常需要修改 wp-content/plugins/woocommerce/templates/cart/cart.php 模板文件,或者更推荐的做法是使用主题的 functions.php 文件通过钩子进行修改。以下示例展示了如何在 cart.php 中(在产品标题下方)添加品牌信息。

 'names'] );

// 检查是否成功获取品牌且没有错误
if ( ! is_wp_error( $brands ) && ! empty( $brands ) ) {
    echo '

'; echo '品牌: ' . implode(', ', $brands); // 如果有多个品牌,用逗号分隔 echo '

'; } // 以下是购物车页面原有的其他产品信息显示代码,例如: // echo apply_filters( 'woocommerce_cart_item_name', $_product->get_name(), $cart_item, $cart_item_key ) . ' '; // ... 其他购物车项信息 ... ?>

代码解释:

  • $_product = apply_filters(...) 和 $product_id = apply_filters(...):这些行用于安全地获取当前购物车项的产品对象和产品 ID。
  • $brand_taxonomy = 'ourbrandname';:这是最关键的一行,您需要将 'ourbrandname' 替换为您通过上述方法找到的实际分类法名称。
  • $brands = wp_get_post_terms(...):使用产品 ID 和正确的分类法名称来获取品牌术语。['fields' => 'names'] 参数确保只返回品牌的名称数组。
  • if ( ! is_wp_error( $brands ) && ! empty( $brands ) ):这是一个重要的错误处理步骤。它检查 wp_get_post_terms 是否返回了 WP_Error 对象(表示失败)以及品牌数组是否为空。只有在成功获取到品牌时才进行显示。
  • echo '

    ';:将品牌名称包裹在

    标签中,并添加一个 CSS 类 product-brand-name,方便后续进行样式定制。

  • implode(', ', $brands):如果一个产品有多个品牌(虽然不常见,但有可能),此函数会将所有品牌名称用逗号和空格连接起来。

注意事项与最佳实践

  1. 避免直接修改核心模板文件:直接修改 wp-content/plugins/woocommerce/templates/cart/cart.php 是不推荐的。因为当 WooCommerce 插件更新时,您的修改会被覆盖。

    • 推荐做法:将 cart.php 文件复制到您的主题(或子主题)的 woocommerce/cart/ 目录下,然后在该复制的文件中进行修改。
    • 更佳实践:使用 WooCommerce 提供的钩子(Action Hooks 和 Filter Hooks)在 functions.php 文件中添加品牌信息,而不是直接修改模板文件。例如,可以使用 woocommerce_after_cart_item_name 钩子。
      // 在 functions.php 中添加此代码
      add_action( 'woocommerce_after_cart_item_name', 'display_product_brand_in_cart', 10, 3 );

    function display_product_brand_in_cart( $cart_item, $cart_item_key ) { $_product = apply_filters( 'woocommerce_cart_item_product', $cart_item['data'], $cart_item, $cart_item_key ); $product_id = apply_filters( 'woocommerce_cart_item_product_id', $cart_item['product_id'], $cart_item, $cart_item_key );

    // 替换 'your_brand_taxonomy' 为您实际找到的品牌分类法名称
    $brand_taxonomy = 'ourbrandname'; 
    
    $brands = wp_get_post_terms( $product_id, $brand_taxonomy, ['fields' => 'names'] );
    
    if ( ! is_wp_error( $brands ) && ! empty( $brands ) ) {
        echo '

    '; echo '品牌: ' . implode(', ', $brands); echo '

    '; }

    }

  2. 错误处理:始终使用 is_wp_error() 检查 wp_get_post_terms 的返回值,以避免在分类法不存在时抛出 PHP 错误。

  3. 性能考量:对于大型网站,频繁调用 wp_get_post_terms 可能会有轻微的性能影响。如果品牌信息不经常变化,可以考虑对结果进行缓存。

  4. 样式定制:为品牌信息添加一个特定的 CSS 类(如 product-brand-name),方便您通过 CSS 文件对其进行样式定制,使其与您的网站设计保持一致。

总结

在 WooCommerce 购物车页面显示产品品牌是一个实用的功能,但正确识别品牌分类法名称是实现这一功能的先决条件。通过检查 WordPress 后台 URL 或审查插件/主题代码,您可以轻松找到正确的分类法名称,并将其集成到您的购物车模板中。遵循最佳实践,使用钩子而非直接修改核心文件,将确保您的改动在网站更新时保持稳定和兼容性。

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

2650

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1657

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1515

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

952

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1418

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1234

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1468

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1306

2023.11.13

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

72

2026.01.16

热门下载

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

精品课程

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

共14课时 | 0.8万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 2.9万人学习

CSS教程
CSS教程

共754课时 | 20.4万人学习

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

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