
本文教你如何在 woocommerce 中实现无论购物车是否为空,用户每次点击“添加到购物车”后均自动跳转至结账页面(checkout),彻底绕过购物车页面,满足单商品、单次结算的业务场景需求。
在 WooCommerce 默认行为中,用户点击“添加到购物车”后通常会停留在当前页面或跳转至购物车页(取决于设置)。但某些业务场景(例如仅销售一件定制商品、预约服务、限时单购等)要求用户完成一次购买流程后必须结算,不允许累积多件商品——此时需强制每次添加后直通结账页。
你原先的代码逻辑存在两个关键问题:
- 条件判断错误:if ( ! WC()->cart->get_cart_contents_count() == 0 ) 实际等价于 if ( ( ! count ) == 0 ),即当购物车为空(count=0 → !0=true → true==0 → false)时条件为假,逻辑完全颠倒;
- 冗余分支与未定义返回:else{} 块内无返回值,且末尾重复赋值+返回,导致函数结构混乱,易触发 PHP 警告或不可预期跳转。
✅ 正确解法极其简洁:无需判断购物车状态。因为你的需求本质是「始终跳转至结账页」,而非「仅当有商品时跳转」。WooCommerce 的 woocommerce_add_to_cart_redirect 过滤器会在每次成功添加商品后触发,此时购物车已更新,直接返回结账 URL 即可。
以下是推荐使用的精简、健壮、兼容性良好的代码:
add_filter( 'woocommerce_add_to_cart_redirect', 'my_force_checkout_redirect' );
function my_force_checkout_redirect() {
return wc_get_checkout_url();
}? 使用说明:
- 将上述代码添加至主题的 functions.php 文件末尾(建议使用子主题),或通过 Code Snippets 插件安全启用;
- wc_get_checkout_url() 是 WooCommerce 官方推荐函数(替代已弃用的 WC()->cart->get_checkout_url()),自动适配自定义结账页设置,兼容性更优;
- 该过滤器仅在「添加成功」时触发(如库存充足、验证通过),失败情况(如缺货、权限不足)不会执行,因此无需额外容错处理。
⚠️ 注意事项:
- 启用后,用户将无法通过“添加到购物车”操作继续浏览或批量选购——请确保此体验符合你的业务逻辑(例如首页仅展示唯一商品,且明确提示“立即购买”);
- 若需保留“查看购物车”入口,建议在按钮文案、样式或页面布局上做引导(如将“添加到购物车”按钮文字改为“立即结算”,并搭配购物车图标);
- 如后续需扩展逻辑(例如仅对特定商品类别强制跳转),可在函数内加入 WC()->cart->get_cart() 或 $_POST['add-to-cart'] 商品 ID 判断,但本例无需复杂化。
至此,无论购物车原本为空还是已含商品,用户每次点击“添加到购物车”都将无缝跳转至结账页,精准实现客户提出的“始终直达结算”需求。










