
本文详解如何在 WooCommerce 单品页中可靠检测产品是否同时拥有指定的两个自定义属性(如 pa_storlek 和 pa_djurart),并基于此条件动态显示附加内容,重点解决因 strpos() 返回 0 被误判为 false 导致的逻辑失效问题。
本文详解如何在 woocommerce 单品页中可靠检测产品是否同时拥有指定的两个自定义属性(如 `pa_storlek` 和 `pa_djurart`),并基于此条件动态显示附加内容,重点解决因 `strpos()` 返回 `0` 被误判为 `false` 导致的逻辑失效问题。
在 WooCommerce 开发中,常需根据产品的自定义属性组合动态渲染内容——例如仅当某商品同时标注尺寸为 “x-small” 且适用动物为 “hund”(瑞典语“狗”)时,才展示「X-Small 狗专用」提示。看似简单的条件判断,却极易因 PHP 类型转换陷阱而失败。
核心问题在于:strpos() 函数在目标子串位于字符串开头时返回整数 0,而 if (0) 在 PHP 中被隐式转换为 false,导致本应成立的条件被跳过。原始代码中:
if( strpos($size, 'x-small') && strpos($animal, 'hund') ) { ... }即使 $size = 'x-small',strpos($size, 'x-small') 返回 0,整个表达式即为 false,始终落入 else 分支。
✅ 正确做法是使用严格比较(!== false),明确区分“未找到”(返回 false)与“找到于起始位置”(返回 0)两种情况:
// X-Small 狗专用信息展示
add_action( 'woocommerce_single_product_summary', 'x_small_dogs', 90 );
function x_small_dogs() {
global $product;
// 获取属性值(注意:get_attribute() 返回已格式化的字符串,含空格/换行需清理)
$size = trim( $product->get_attribute('pa_storlek') );
$animal = trim( $product->get_attribute('pa_djurart') );
// 严格检查:两个属性值均包含指定关键词(不区分大小写更稳妥)
if ( stripos($size, 'x-small') !== false && stripos($animal, 'hund') !== false ) {
echo '<div class="product-tag product-tag-xs-dog">X-Small</div>';
} else {
echo '<div class="product-tag product-tag-fallback">Inte X-small</div>';
}
}? 关键优化说明:
- 使用 stripos() 替代 strpos(),避免因大小写不一致(如 X-SMALL 或 Hund)导致匹配失败;
- 对属性值调用 trim(),消除 WooCommerce 属性前端输入可能带入的首尾空格或换行符;
- 为输出 添加语义化 CSS 类名,便于后续样式控制与 JavaScript 操作;
- 钩子优先级设为 90,确保在产品摘要区域(如价格、加购按钮)之后渲染,位置合理。
⚠️ 注意事项:
- get_attribute() 仅对已发布且已分配值的属性有效;若属性未设置,返回空字符串,stripos('', 'x-small') 返回 false,符合预期;
- 若需精确匹配完整属性项(而非子串),应改用 $product->get_terms() 获取术语对象,并比对 term_slug 或 name;
- 多语言站点建议结合 ICL_LANGUAGE_CODE 或 pll_current_language() 做语言上下文适配,避免跨语言属性值差异影响判断。
通过这一严谨的字符串检测模式,您可安全扩展至任意多属性联合校验场景——只需将 && 条件链式叠加,并统一采用 !== false 严格判定,即可构建健壮、可维护的产品条件渲染逻辑。










