信息发布→ 登录 注册 退出

WooCommerce 购物车:始终显示所有交叉销售商品

发布时间:2025-11-29

点击量:

woocommerce 购物车:始终显示所有交叉销售商品

本教程详细介绍了如何通过使用 `woocommerce_cart_crosssell_ids` 过滤器,修改 WooCommerce 购物车默认的交叉销售商品显示逻辑。通过自定义函数,您可以确保购物车中始终展示与当前商品相关联的所有交叉销售商品,而不再自动排除已添加到购物车的商品,从而优化商品推荐策略。

在 WooCommerce 中,购物车页面通常会推荐与当前购物车商品相关的交叉销售(Cross-sell)商品。然而,默认情况下,WooCommerce 的核心功能会智能地从交叉销售列表中移除那些已经存在于购物车中的商品。这一逻辑由 WC_Cart 类中的 get_cross_sells() 方法控制,具体是通过 array_diff( $cross_sells, $in_cart ) 这一行代码实现,其目的是避免重复推荐用户已购买的商品。

对于某些业务场景,例如希望最大化商品曝光或提供更多购买选项,可能需要覆盖这一默认行为,让购物车页面始终显示所有关联的交叉销售商品,无论它们是否已在购物车中。本教程将指导您如何通过 WooCommerce 提供的过滤器钩子来实现这一目标。

理解 WooCommerce 交叉销售逻辑

WooCommerce 的 get_cross_sells() 方法首先会遍历购物车中的每一个商品,收集它们各自关联的交叉销售商品 ID,并将其合并到一个数组中。随后,它会移除那些已经存在于购物车中的商品 ID。我们目标是跳过或重写这一“移除”步骤。

使用 woocommerce_cart_crosssell_ids 过滤器

WooCommerce 提供了 woocommerce_cart_crosssell_ids 过滤器钩子,允许开发者完全控制最终呈现在购物车页面的交叉销售商品 ID 列表。通过这个过滤器,我们可以重新构建交叉销售商品 ID 数组,确保其中包含所有关联商品,而无需考虑它们是否已在购物车中。

实施步骤

要实现始终显示所有交叉销售商品,您需要将以下 PHP 代码添加到您子主题的 functions.php 文件中,或者通过自定义插件引入。

/**
 * 过滤 woocommerce_cart_crosssell_ids,以显示所有交叉销售商品。
 *
 * @param array    $cross_sells 当前交叉销售商品 ID 数组。
 * @param WC_Cart  $cart        WC_Cart 实例。
 * @return array   更新后的交叉销售商品 ID 数组。
 */
function filter_woocommerce_cart_crosssell_ids( $cross_sells, $cart ) {
    // 初始化一个空数组,用于收集所有交叉销售商品 ID
    $all_cross_sells_ids = array();

    // 遍历购物车中的每一个商品
    foreach ( $cart->get_cart() as $cart_item_key => $values ) {
        // 确保商品数量大于0
        if ( $values['quantity'] > 0 ) {
            // 获取当前购物车商品的交叉销售商品 ID,并与已收集的 ID 合并
            // 注意:这里我们直接合并,不进行任何移除已在购物车商品的判断
            $all_cross_sells_ids = array_merge( $values['data']->get_cross_sell_ids(), $all_cross_sells_ids );
        }
    }

    // 使用 wp_parse_id_list 清理并确保 ID 列表的唯一性
    // 这将移除重复的 ID,并确保所有 ID 都是有效的整数
    $cross_sells = wp_parse_id_list( $all_cross_sells_ids );

    return $cross_sells;
}
add_filter( 'woocommerce_cart_crosssell_ids', 'filter_woocommerce_cart_crosssell_ids', 10, 2 );

代码解释

  1. filter_woocommerce_cart_crosssell_ids( $cross_sells, $cart ) 函数定义

    佳可商务购物程序 2004 佳可商务购物程序 2004

    在原版的基础上做了一下修正评论没有提交正文的问题特价商品的调用连接问题去掉了一个后门补了SQL注入补了一个过滤漏洞浮动价不能删除的问题不能够搜索问题收藏时放入购物车时出错点放入购物车弹出2个窗口修正主题添加问题商家注册页导航连接问题销售排行不能显示更多问题热点商品不能显示更多问题增加了服务器探测 增加了空间使用查看 增加了在线文件编辑增加了后台管理里两处全选功能更新说明:后台的部分功能已经改过前台

    佳可商务购物程序 2004 0 查看详情 佳可商务购物程序 2004
    • 这个函数是我们的自定义逻辑,它接收两个参数:$cross_sells(WooCommerce 默认计算出的交叉销售 ID 数组)和 $cart(当前的 WC_Cart 对象实例)。
    • 虽然 $cross_sells 参数会被传入,但我们的逻辑实际上会完全重新构建这个列表,而不是基于它进行修改。
  2. $all_cross_sells_ids = array();

    • 初始化一个空数组,用于存储从购物车所有商品中收集到的交叉销售商品 ID。
  3. foreach ( $cart->get_cart() as $cart_item_key => $values ) 循环

    • 遍历购物车中的每个商品项。
    • $values['data']->get_cross_sell_ids():获取当前购物车商品关联的所有交叉销售商品 ID。
    • array_merge( ..., $all_cross_sells_ids ):将当前商品的交叉销售 ID 与之前收集的 ID 合并到 $all_cross_sells_ids 数组中。这里的关键在于,我们只进行合并操作,不执行任何 array_diff 来排除已在购物车中的商品。
  4. $cross_sells = wp_parse_id_list( $all_cross_sells_ids );

    • wp_parse_id_list() 是一个 WordPress 实用函数,它能够清理并确保 ID 列表的有效性。它会将输入的 ID 列表转换为一个唯一的整数 ID 数组,移除任何非数字或重复的项。这对于最终输出一个干净的交叉销售 ID 列表非常重要。
  5. add_filter( 'woocommerce_cart_crosssell_ids', 'filter_woocommerce_cart_crosssell_ids', 10, 2 );

    • 将我们的自定义函数挂载到 woocommerce_cart_crosssell_ids 过滤器上。
    • 10 是优先级,表示在默认优先级下执行。
    • 2 表示我们的函数接受两个参数($cross_sells 和 $cart)。

注意事项与最佳实践

  • 代码位置:强烈建议将此类自定义代码放置在子主题的 functions.php 文件中,或者创建一个独立的自定义插件。直接修改 WooCommerce 核心文件或父主题文件会导致更新时丢失您的更改。
  • 性能考量:对于包含大量商品和复杂交叉销售关系的大型商店,此操作可能会对购物车页面的加载性能产生轻微影响。在大多数情况下,这种影响可以忽略不计。
  • 用户体验:虽然显示所有交叉销售商品可能增加曝光,但也需注意不要让购物车页面过于冗长或信息过载,从而影响用户体验。
  • 测试:在生产环境部署之前,务必在开发或测试环境中充分测试此功能,确保其按预期工作且没有引入其他兼容性问题。

总结

通过利用 woocommerce_cart_crosssell_ids 过滤器,您可以轻松地自定义 WooCommerce 购物车中交叉销售商品的显示行为。上述教程提供的方法能够确保所有关联的交叉销售商品都得以展示,为您的客户提供更全面的商品推荐,并可能促进额外的销售。记住始终遵循最佳实践,将代码放置在正确的位置并进行充分测试。

以上就是WooCommerce 购物车:始终显示所有交叉销售商品的详细内容,更多请关注php中文网其它相关文章!


相关文章: 漫蛙2网页版漫画入口 漫蛙漫画在线官方登录  提升屏幕阅读器对“m”时间单位的播报准确性:HTML与CSS组合解决方案  Composer的 "licenses" 命令如何帮助你遵守开源协议_检查项目依赖的许可证合规性  邮编格式怎么匹配地址_根据邮编格式快速匹配详细地址的技巧  C++如何解决segmentation fault_C++段错误调试与原因分析  如何在PHP中实现基于MySQL的动态分页查询  Python中高效且防溢出的双曲正弦计算:基于对数空间的优化策略  葱吃多了会怎样 葱吃多了会伤胃吗  Lar*el拼写容错搜索策略:基于语音编码的优化实践  J*aScript 字符串标签转换:使用正则表达式高效替换  b站如何看历史记录_b站观看历史找回方法  J*aScript中在Map循环中检测并处理空数组元素  Sublime怎么配置Nim语言环境_Sublime Nim代码高亮与补全  uc浏览器网页版极速入口 uc网页浏览器网页版流畅体验  优化Django表单:提交验证失败后保留用户输入  厨房不锈钢水槽发黑生锈怎么处理_水槽用可乐+锡纸2分钟抛亮如新  c++中的const_cast和reinterpret_cast怎么用_c++四种类型转换  2026春节假期时间安排 2026春节假日查询  微信网页版官方快速登录入口 微信网页版网页版账号直达  Win11怎么设置鼠标指针速度_Win11提高鼠标指针精确度选项  使用 Pandas 高效处理 .dat 文件:数据清洗与数值计算实战  qq浏览器打开空白页怎么办 qq浏览器启动后显示白屏的解决教程  Win11怎么开启高性能模式_Windows 11电源计划优化设置  Win10如何开启蓝牙功能_Windows10找不到蓝牙开关解决方法  J*aScript Promise链中如何正确终止后续.then执行并处理错误  msn官网入口地址手机版 msn官方网站手机最新链接  使用Pandas转换并合并DataFrame:多列映射至统一结构  12306选座系统怎么选连座_12306选座多人连坐操作方法  自定义Bag-of-Words实现:处理带负号的词汇权重  MAC如何将整个网页截长图_MAC使用Safari的导出为PDF或第三方工具  零跑汽车11月交付量达70327台 实现连续9个月正增长  QQ邮箱稳定登录入口_QQ邮箱官方网站网页版使用  Go与Ruby之间实现AES加密互通:CFB模式下的密钥长度匹配策略  深入理解Google Cloud Datastore查询:祖先路径与数据一致性  Centos/Linux 系统下安装 composer 的完整步骤  Golang如何使用bytes.Split分割字节切片_Golang bytes切片分割方法  微博网页版官方账号登录 微博网页版内容浏览使用指南  EMS快递官网app_中国邮政速递物流手机客户端  小红书网页版入口链接分享 小红书官网直接进  Excel组合图表怎么做 Excel创建柱状图与折线组合图教程【图表】  Django表单验证失败时保留用户输入数据的最佳实践  TikTok国际版官网直达_TikTok国际版官网直达进入在线观看  qq游戏跨平台入口_qq游戏多设备同步登录  树莓派传感器触发:通过Twilio API发送WhatsApp消息教程  如何修改开机登录密码_Windows账户安全设置超详细教程【必学】  qq浏览器如何查看和导出已保存的密码 qq浏览器密码管理器数据备份教程  京东单号查询入口_京东快递订单追踪入口  学习通在线学习平台 学习通网页版直接进入课程中心  BetterDiscord插件中安全更新用户简介的实践指南  Yandex官网免登录入口_俄罗斯Yandex搜索引擎一键访问 

在线客服
服务热线

服务热线

4008988990

微信咨询
二维码
返回顶部
×二维码

截屏,微信识别二维码

打开微信

微信号已复制,请打开微信添加咨询详情!