
本教程旨在指导用户如何为WooCommerce商店中的外部商品添加“在新标签页打开”的购物车按钮。通过修改functions.php文件,我们可以自定义商店页面和商品详情页的“添加到购物车”按钮,使其链接在新标签页中打开,从而改善用户体验,尤其是在使用联盟链接时。
修改functions.php文件
要实现“在新标签页打开”的功能,我们需要修改WordPress主题的functions.php文件。 请注意,直接修改主题文件存在风险,建议使用子主题或代码片段插件进行修改,以避免主题更新导致更改丢失。
以下代码片段将为商店页面和商品详情页的外部商品添加target=”_blank”属性,使其链接在新标签页中打开:
// 为商店页面添加自定义按钮add_filter('woocommerce_loop_add_to_cart_link', 'shop_page_open_external_in_new_window', 10, 2);function shop_page_open_external_in_new_window($link){ global $product; if ($product->is_type('external')) { $link = sprintf( '%s', esc_url($product->add_to_cart_url()), esc_attr(isset($quantity) ? $quantity : 1), esc_attr($product->get_id()), esc_attr($product->get_sku()), esc_attr(isset($class) ? $class : 'button product_type_external'), esc_html($product->add_to_cart_text()) ); } return $link;}// 移除商品详情页默认按钮remove_action('woocommerce_external_add_to_cart', 'woocommerce_external_add_to_cart', 30);// 为商品详情页添加自定义按钮add_action('woocommerce_external_add_to_cart', 'product_page_open_external_in_new_window', 30);function product_page_open_external_in_new_window(){ global $product; if (!$product->add_to_cart_url()) { return; } $product_url = $product->add_to_cart_url(); $button_text = $product->single_add_to_cart_text(); do_action('woocommerce_before_add_to_cart_button'); ?> <a href="" rel="nofollow" class="single_add_to_cart_button button alt" target="_blank">
<?php do_action('woocommerce_after_add_to_cart_button');}
代码解释
商店页面自定义按钮:
add_filter(‘woocommerce_loop_add_to_cart_link’, ‘shop_page_open_external_in_new_window’, 10, 2);: 使用woocommerce_loop_add_to_cart_link过滤器,允许我们修改商店页面上的“添加到购物车”链接。shop_page_open_external_in_new_window($link) 函数:使用global $product;访问当前产品对象。if ($product->is_type(‘external’)):检查产品类型是否为“external”(外部/联盟商品)。sprintf(…):构建新的链接字符串,关键是添加了target=”_blank”属性。esc_url() 和 esc_attr():用于安全地转义URL和属性,防止安全漏洞。esc_html(): 用于安全地转义HTML文本,防止安全漏洞。
商品详情页自定义按钮:
remove_action(‘woocommerce_external_add_to_cart’, ‘woocommerce_external_add_to_cart’, 30);:移除WooCommerce默认的外部商品“添加到购物车”按钮。add_action(‘woocommerce_external_add_to_cart’, ‘product_page_open_external_in_new_window’, 30);:添加我们自定义的按钮。product_page_open_external_in_new_window() 函数:与商店页面类似,获取产品URL和按钮文本。使用HTML直接输出包含target=”_blank”属性的链接。do_action(‘woocommerce_before_add_to_cart_button’); 和 do_action(‘woocommerce_after_add_to_cart_button’);: 允许其他插件或主题在按钮前后添加内容。
使用方法
备份functions.php文件: 在进行任何修改之前,务必备份你的functions.php文件。选择修改方式: 推荐使用子主题或代码片段插件。子主题: 如果你还没有子主题,请创建一个。将上述代码添加到子主题的functions.php文件中。代码片段插件: 安装并激活一个代码片段插件(如Code Snippets)。将上述代码添加到插件中,并启用该代码片段。测试: 访问你的WooCommerce商店页面和商品详情页,检查外部商品的“添加到购物车”按钮是否在新标签页中打开。
注意事项
主题更新: 如果你直接修改了主题的functions.php文件,主题更新将会覆盖你的修改。因此,强烈建议使用子主题或代码片段插件。代码冲突: 某些插件或主题可能与此代码冲突。如果遇到问题,请尝试禁用其他插件或更换主题进行排查。安全性: 确保你从可信来源获取代码,并始终进行安全检查。缓存: 修改functions.php文件后,可能需要清除网站缓存才能看到更改。
总结
通过以上步骤,你可以轻松地为WooCommerce商店中的外部商品添加“在新标签页打开”的购物车按钮。 这可以显著改善用户体验,尤其是在使用联盟链接时,用户无需离开你的网站即可访问外部商家的页面。 请记住,在进行任何代码修改之前,务必备份你的网站,并仔细测试修改后的功能。
以上就是为WooCommerce外部商品添加“在新标签页打开”的购物车按钮的详细内容,更多请关注php中文网其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1273611.html
微信扫一扫
支付宝扫一扫