[英]WooCommerce: Stop scrolling to error message on checkout page
如果结帐表单上有错误,WooCommerce 通常会滚动到.form.checkout
。 我希望它停止,因为它以某种方式干扰了 ScrollMagic.js。
如果我不排队 ScrollMagic.js 一切正常,但启用 ScrollMagic.js 页面只是跳到顶部。
我尝试使用$(document.body).on('checkout_error', function () { $( 'html, body' ).stop(); }
但它不起作用。
如果我使用
$(document.body).on('checkout_error', function () {
// There was a validation error
console.log('checkout_error triggered');
});
控制台中没有日志消息。 为什么什么都没有发生? 如何停止 WooCommerce 动画?
根据这篇文章你可以试试这个吗?
jQuery( document ).ajaxComplete( function() {
if ( jQuery( 'body' ).hasClass( 'woocommerce-checkout' ) || jQuery( 'body' ).hasClass( 'woocommerce-cart' ) ) {
jQuery( 'html, body' ).stop();
}
} );
现在我的控制台日志出现了。 我根本没有改变任何东西,但是jQuery('html, body').stop();
不会触发。
但是通过使用 GSAP ScrollToPlugin 我现在可以滚动到ul.woocommerce-error
使用
$(document.body).on('checkout_error', function () {
TweenLite.to(window, 1, {scrollTo:"ul.woocommerce-error"});
console.log('checkout_error triggered');
});
如此处所述: https : //greensock.com/ScrollToPlugin 。
我知道这是一个非常古老的话题,但我找到了更简单的解决方案。 只需编辑 3 个通知模板(error.php、notice.php、success.php)并删除 role="alert" 就可以了。 滚动功能找不到要滚动到的元素。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.