0

0

WooCommerce 单品页复制购物车按钮并实现自定义重定向

心靈之曲

心靈之曲

发布时间:2025-10-03 12:43:16

|

847人浏览过

|

来源于php中文网

原创

WooCommerce 单品页复制购物车按钮并实现自定义重定向

本文旨在提供一个在 WooCommerce 单品页复制“加入购物车”按钮并将其重定向至自定义页面的教程。通过在现有按钮下方添加一个功能相同的副本,并结合 JavaScript 动态注入标识和 PHP 过滤器,我们能够根据用户点击的按钮类型,在产品添加到购物车后将其引导至不同的目标页面,同时确保所有核心购物车功能(如自定义购物车商品数据)得以保留。

在许多定制化的 woocommerce 网店中,可能需要为产品提供除了标准“加入购物车”并跳转到购物车页面之外的选项,例如“加入报价单”并跳转到报价单页面。这种需求的核心挑战在于,既要复制“加入购物车”按钮的所有后端功能(例如处理自定义购物车商品数据),又要能够灵活地控制其重定向行为。本教程将详细介绍如何通过三步实现这一目标:添加一个功能类似的按钮、动态地为该按钮的提交行为添加一个标识,以及利用 woocommerce 的重定向过滤器来响应这个标识。

1. 添加自定义功能按钮

首先,我们需要在单品页上添加一个与现有“加入购物车”按钮功能相似的新按钮。为了不直接修改模板文件,我们可以利用 WooCommerce 提供的动作钩子,例如 woocommerce_after_add_to_cart_button,在现有按钮下方插入新按钮。这个新按钮将包含一个独特的 CSS 类,以便后续通过 JavaScript 进行识别。

以下代码演示了如何为简单商品和可变商品添加一个名为“我的新文本”的按钮副本:

/**
 * 在“加入购物车”按钮下方添加一个新按钮
 */
function custom_add_to_cart_duplicate_button() {
    global $product;

    // 定义按钮文本
    $button_text = __( '我的新文本', 'woocommerce' );

    // 确保当前是 WooCommerce 产品页
    if ( is_a( $product, 'WC_Product' ) ) {
        // 针对简单商品
        if ( $product->is_type( 'simple' ) ) {
            echo '';
        // 针对可变商品
        } elseif( $product->is_type( 'variable' ) ) {
            // 可变商品不需要 value 属性,因为其 ID 会通过表单的其他字段传递
            echo '';
        }
    }
}
add_action( 'woocommerce_after_add_to_cart_button', 'custom_add_to_cart_duplicate_button', 10 );

代码说明:

  • 我们使用了 woocommerce_after_add_to_cart_button 钩子,确保新按钮出现在标准“加入购物车”按钮之后。
  • 新按钮的 type="submit" 和 name="add-to-cart" 属性使其能够触发与原始按钮相同的“加入购物车”逻辑。
  • 关键在于 custom_redirect_button 这个 CSS 类。它将作为我们识别这个特定按钮的唯一标识,用于下一步的 JavaScript 处理。

2. 动态注入重定向标识

为了区分用户点击的是原始“加入购物车”按钮还是我们新添加的按钮,我们需要在用户点击新按钮时,向表单提交的数据中添加一个特殊的标识。这可以通过 JavaScript (jQuery) 实现,在按钮被点击时动态地插入一个隐藏的 input 字段。

以下代码展示了如何在页脚添加 jQuery 脚本,以监听 custom_redirect_button 的点击事件,并注入一个隐藏字段:

科大讯飞-AI虚拟主播
科大讯飞-AI虚拟主播

科大讯飞推出的移动互联网智能交互平台,为开发者免费提供:涵盖语音能力增强型SDK,一站式人机智能语音交互解决方案,专业全面的移动应用分析;

下载
/**
 * 通过 jQuery 在点击自定义按钮时注入隐藏字段
 */
function custom_add_to_cart_js_injector() {
    // 仅在单品页加载此脚本
    if ( is_product() ) {
        ?>
        
        

代码说明:

  • wp_footer 钩子用于在页脚加载 JavaScript,确保 DOM 元素已完全加载。
  • is_product() 函数确保脚本只在单品页上执行。
  • 当 custom_redirect_button 被点击且未禁用时,一个名为 custom-redirect 且值为 my-value 的隐藏 input 字段会被添加到表单中。这个字段将随表单一起提交到服务器。

3. 实现条件式重定向逻辑

最后一步是利用 WooCommerce 的 woocommerce_add_to_cart_redirect 过滤器来检查提交的数据中是否存在我们注入的隐藏字段。如果存在且值匹配,我们就将重定向 URL 修改为我们自定义的目标页面。

/**
 * 根据自定义标识修改“加入购物车”后的重定向 URL
 */
function custom_add_to_cart_conditional_redirect( $redirect_url, $product ) {
    // 检查是否存在我们自定义的重定向标识
    if ( isset( $_REQUEST['custom-redirect'] ) ) {
        // 如果标识的值与我们设置的 'my-value' 匹配
        if ( $_REQUEST['custom-redirect'] == 'my-value' ) {
            // 设置自定义的重定向 URL
            // get_permalink(1) 是一个示例,表示重定向到 ID 为 1 的页面
            // 您可以替换为任何有效的 URL 或页面 ID
            $redirect_url = get_permalink( 1 );
        }
    }

    return $redirect_url;
}
add_filter( 'woocommerce_add_to_cart_redirect', 'custom_add_to_cart_conditional_redirect', 10, 2 );

代码说明:

  • woocommerce_add_to_cart_redirect 过滤器允许我们修改产品添加到购物车后的默认重定向 URL。它接收当前重定向 URL 和产品对象作为参数。
  • 我们通过 $_REQUEST['custom-redirect'] 检查之前通过 JavaScript 注入的隐藏字段是否存在。
  • 如果存在且其值是 my-value,则意味着用户点击的是我们的自定义按钮,此时我们将 $redirect_url 更新为 get_permalink(1)(请将 1 替换为您希望重定向到的页面 ID 或使用其他方法获取 URL)。

注意事项

  • 保留核心功能: 这种方法的核心优势在于,新的按钮仍然触发了标准的 WooCommerce “加入购物车”流程。这意味着所有依赖于 woocommerce_add_to_cart 动作或其他相关钩子的自定义功能(例如添加购物车商品数据 woocommerce_add_cart_item_data)都将正常工作。
  • 目标页面 ID: 在第三步中,get_permalink(1) 是一个示例。在实际应用中,您应该将其替换为您的自定义目标页面的实际 ID。您也可以通过页面标题、slug 或其他配置选项来动态获取页面 ID。
  • 按钮样式: 新添加的按钮默认会继承 WooCommerce 的按钮样式。如果需要独特的视觉效果,可以通过 CSS 为 .custom_redirect_button 类添加自定义样式。
  • 测试: 在生产环境中使用之前,务必在开发环境中进行全面测试,以确保所有功能按预期工作,特别是与现有自定义代码的兼容性。
  • 可变商品: 对于可变商品,虽然新按钮也带有 single_add_to_cart_button 类,但其 value 属性通常由 WooCommerce 的 JavaScript 在选择变体后动态更新。本教程中的代码已考虑了这一点,对于可变商品,我们不为按钮直接设置 value 属性,而是依赖 WooCommerce 自身的机制来处理变体 ID。

总结

通过上述三步策略,我们成功地在 WooCommerce 单品页上复制了一个“加入购物车”按钮,并为其实现了自定义的重定向逻辑。这种方法不仅功能强大,而且具有良好的扩展性,因为它利用了 WooCommerce 自身的钩子和过滤器,最大限度地减少了对核心代码的侵入,并确保了现有自定义功能的兼容性。无论是用于“加入报价单”、“加入愿望清单”还是其他特殊功能,这种模式都能提供灵活且可靠的解决方案。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
jquery插件有哪些
jquery插件有哪些

jquery插件有jQuery UI、jQuery Validate、jQuery DataTables、jQuery Slick、jQuery LazyLoad、jQuery Countdown、jQuery Lightbox、jQuery FullCalendar、jQuery Chosen和jQuery EasyUI等。本专题为大家提供jquery插件相关的文章、下载、课程内容,供大家免费下载体验。

150

2023.09.12

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

311

2023.10.13

jquery删除元素的方法
jquery删除元素的方法

jquery可以通过.remove() 方法、 .detach() 方法、.empty() 方法、.unwrap() 方法、.replaceWith() 方法、.html('') 方法和.hide() 方法来删除元素。更多关于jquery相关的问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

394

2023.11.10

jQuery hover()方法的使用
jQuery hover()方法的使用

hover()是jQuery中一个常用的方法,它用于绑定两个事件处理函数,这两个函数将在鼠标指针进入和离开匹配的元素时执行。想了解更多hover()的相关内容,可以阅读本专题下面的文章。

502

2023.12.04

jquery实现分页方法
jquery实现分页方法

在jQuery中实现分页可以使用插件或者自定义实现。想了解更多jquery分页的相关内容,可以阅读本专题下面的文章。

182

2023.12.06

jquery中隐藏元素是什么
jquery中隐藏元素是什么

jquery中隐藏元素是非常重要的一个概念,在使用jquery隐藏元素之前,需要先了解css样式中关于元素隐藏的属性,比如display、visibility、opacity等属性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

120

2024.02.23

jquery中什么是高亮显示
jquery中什么是高亮显示

jquery中高亮显示是指对页面搜索关键词时进行高亮显示,其实现办法:1、先获取要高亮显示的行,获取搜索的内容,再遍历整行内容,最后添加高亮颜色;2、使用“jquery highlight”高亮插件。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

176

2024.02.23

jQuery 正则表达式相关教程
jQuery 正则表达式相关教程

本专题整合了jQuery正则表达式相关教程大全,阅读专题下面的文章了解更多详细内容。

38

2026.01.13

Python 自然语言处理(NLP)基础与实战
Python 自然语言处理(NLP)基础与实战

本专题系统讲解 Python 在自然语言处理(NLP)领域的基础方法与实战应用,涵盖文本预处理(分词、去停用词)、词性标注、命名实体识别、关键词提取、情感分析,以及常用 NLP 库(NLTK、spaCy)的核心用法。通过真实文本案例,帮助学习者掌握 使用 Python 进行文本分析与语言数据处理的完整流程,适用于内容分析、舆情监测与智能文本应用场景。

10

2026.01.27

热门下载

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

精品课程

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

共14课时 | 0.8万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3万人学习

CSS教程
CSS教程

共754课时 | 24.3万人学习

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

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