在结帐时禁用WooCommerce的AJAX

问题描述 投票:3回答:5

我想问一下如何在结帐页面(您输入运费和结算信息)中禁用AJAX,而不是使用AJAX根据您的位置更新购物车摘要,它会通过自然刷新进行更新。

目前,只要用户通过送货地点切换其位置,购物车摘要就会自动更新,而无需重新加载页面。我想删除那个AJAX,只是让页面重新加载更新的信息。

我不太确定我应该指出什么样的代码或方向,但我已准备好提供必要的任何细节。请告诉我!谢谢!!

php ajax wordpress woocommerce
5个回答
9
投票

所有WooCommerce字符串都使用wp_localize_script正确本地化,所以我认为你可以通过创建适当的.po / .mo文件来正确翻译它们,但我承认没有很多翻译经验。供参考:所有可用的语言包都是at Github,您可能还想阅读documentation

无论如何,结帐脚本都在checkout.js。像任何脚本一样,只要你知道手柄就可以通过wp_dequeue_script()将它出列。

function so_27023433_disable_checkout_script(){
    wp_dequeue_script( 'wc-checkout' );
}
add_action( 'wp_enqueue_scripts', 'so_27023433_disable_checkout_script' );

1
投票

我有一个类似的问题,而不是删除整个脚本,我去看看事件何时创建,我发现了这一点。

$( document.body ).bind( 'update_checkout', this.update_checkout );

读了一下之后,我发现由于命名空间我无法解除绑定,所以我联系了on事件,因为我无法阻止默认我停止了事件的传播。

这些解决了我的问题。

jQuery(document.body).on('update_checkout', function(e){
    //e.preventDefault();
    //e.stopPropagation();
    e.stopImmediatePropagation();
    //console.log(e);
});

0
投票

如果您遵循checkout.js源代码的逻辑,您会注意到通过更改结帐表单的类名可以安全地禁用与编辑计费地址相关的这些AJAX操作。是的,我知道,就这么简单。因此,而不是form.checkout使它成为form.checkout1 .checkout1只是一个虚构的类名(它不必是真实的/存在的)。

以下示例代码可帮助您了解所需内容:

var default_class = 'checkout';
var mask_class = 'checkout1';

// hijack the form's AJAX by changing form's default class name
$('form.'+default_class).addClass(mask_class).removeClass(default_class);

// restore the original class name whenever you want it
$('form.'+mask_class).addClass(default_class).removeClass(mask_class);

请注意,这是一个没有记录的黑客。但是,他们可以随时更改结帐表单功能,因此请记住这一点。我可以确认它适用于WC 2.6.14,也可能在早期版本中。


0
投票

我们遇到了类似的问题:在quote list checkout上加载了结帐脚本。脚本再次通过另一个插件加载(WooCommerce Germanized)。

我们的解决方案更明确:

  • 在页面上配置自定义字段,您不希望加载结帐脚本。

然后:

add_action('wp_enqueue_scripts', 'myprefix_dequeue_woocommerce_checkout', 10000);

function myprefix_dequeue_woocommerce_checkout() {
  if (get_post_meta(get_the_ID(), 'disable_woocommerce_checkout_scripts')) {
    wp_dequeue_script('wc-checkout');
    wp_dequeue_script('wc-gzd-checkout');
    wp_dequeue_script('wc-gzdp-checkout');
  }
}

-1
投票

一种不禁用checkout.js的方法。

首先,有可能加载checkout.min.js而不是checkout.js。

然后评论2行:

update_checkout:function(){
    //b.reset_update_checkout_timer(),
    //b.updateTimer=setTimeout(b.update_checkout_action,"5")
},

然后你的结帐页面将是ajax免费!

© www.soinside.com 2019 - 2024. All rights reserved.