javascript - WooCommerce 购物车数量按钮仅在重新加载后显示

标签 javascript php jquery wordpress woocommerce

我在我的子主题中创建了购物车模板的副本,并对购物车行为进行了一些自定义更改(如 hibr.com 中的 CSS 侧购物车)。我的 header.php 中有这些与购物车相关的片段:

<div class="close-me2"></div>
<?php echo do_shortcode('[woocommerce_cart]'); ?>




<div class="cart-outer" data-user-set-ocm="<?php echo $userSetSideWidgetArea; ?>">
        <div class="cart-menu-wrap">
            <div class="cart-menu">
                <a class="cart-contents" href="<?php //echo $woocommerce->cart->get_cart_url(); ?>"><div class="cart-icon-wrap"><i class="icon-salient-cart"></i> <div class="cart-wrap"><span><?php echo $woocommerce->cart->cart_contents_count; ?> </span></div> </div></a>
            </div>
        </div>



<div id="side-cart">
<div class="close-me2"></div>
<?php echo do_shortcode('[woocommerce_cart]'); ?>

<?php if ( is_active_sidebar( 'sidebar-4' ) ) : ?>
    <div class="widget-area">
        <?php dynamic_sidebar( 'sidebar-4' ); ?>
    </div>
<?php endif; ?>

不幸的是,每当将产品添加到购物车时,由于没有显示数量按钮“-+”,因此似乎会显示“错误”的购物车。刷新页面后,购物车将显示并带有数量按钮:http://screencast.com/t/gzkb6QPfz

我也安装了这个插件:wordpress.org/plugins/woocommerce-ajax-add-to-cart-for-variable-products/changelog/

自从需要触发我的侧车以来,这些是我添加到其中的自定义更改:

// Changes button classes
            $thisbutton.addClass( 'added' );

            var rightVal = 0; // base value
            $('#side-cart').animate({right: rightVal + 'px'}, {queue: false, duration: 500});

            $('.cart-outer a').attr("href", "javascript:void(0)");



            $('#side-cart .woocommerce').removeAttr('style');

            $('#side-cart .widget-area').removeAttr('style');


            $('.cart_empty3').attr('style', 'display:none !important;');

在我看来,将产品添加到购物车后,某些脚本无法正确加载,但我不知道从哪里开始寻找错误。

如果您有任何想法,请告诉我。如果需要,我将分享该网站的链接,因为我目前正在运行 http 身份验证。

谢谢!

最佳答案

我已经解决了覆盖quantity-input.php后的显示问题,如下所示:

<div class="quantity buttons_added">
<input type="button" value="-" class="minus">
	<input type="number" step="<?php echo esc_attr( $step ); ?>" min="<?php echo esc_attr( $min_value ); ?>" max="<?php echo esc_attr( $max_value ); ?>" name="<?php echo esc_attr( $input_name ); ?>" value="<?php echo esc_attr( $input_value ); ?>" title="<?php echo esc_attr_x( 'Qty', 'Product quantity input tooltip', 'woocommerce' ) ?>" class="input-text qty text" size="4" />
<input type="button" value="+" class="plus"></div>
</div>

并使用此 jquery 为 qty 按钮提供触发器:

jQuery(document).ready(function($){
    $('.quantity').on('click', '.plus', function(e) {
        $input = $(this).prev('input.qty');
        var val = parseInt($input.val());
        $input.val( val+1 ).change();
    });

    $('.quantity').on('click', '.minus', 
        function(e) {
        $input = $(this).next('input.qty');
        var val = parseInt($input.val());
        if (val > 0) {
            $input.val( val-1 ).change();
        } 
    });
});

但是现在的问题仍然是,将产品添加到购物车后,数量按钮“+”和“-”只能在重新加载页面后才能单击。

在我看来,jquery 没有正确加载。你对此有什么线索还是我的 jquery 错了?

谢谢!

关于javascript - WooCommerce 购物车数量按钮仅在重新加载后显示,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36788871/

相关文章:

PHP 写一个大文件 - 缓存 RAM

php - 在 CentOS 7.1 和 Laravel 5.1 上,Int 在 PHP 中被处理为字符串

jquery - 同一 HTML 文档中的多个相同 ID

jquery - 选中所有复选框

php - 启用 PHP 对 Windows 中文件夹的访问

javascript - 只有第一个随机引用淡入

javascript - 滚动延迟时的事件链接

javascript - DOM 引用变量如何工作

jquery - 如何使用 jQuery 为文本颜色设置动画?

javascript - 无法使用 Puppeteer 从 dolartoday.com 抓取输入值