我正在开发具有一些高级 jQuery 功能的购物车。除了出现在购物车中商品旁边的从购物车中删除商品按钮之外,我已经完成了所有工作。我很难弄清楚如何定位需要更改回 0 的页面左侧的值。
我做了一个 jsfiddle:http: //jsfiddle.net/richcoy/GpUWn/
如果您按下向上按钮将商品添加到购物车,您将看到它出现在购物车中。该项目旁边是一个 X 按钮,用于将其从购物车中删除。单击该按钮时,它需要将购物车中的值和向上按钮旁边的值都设置回零。
我知道 JS 末尾的 close.click 函数会触发,但无法弄清楚是什么将左侧的值归零。
HTML
<div id="body_container">
<div id="product_container">
<div class="product_box">
<div class="item_name">Item One</div>
<div class="product">0</div>
<button class="up category_one_up">Up</button>
<button class="down category_one_down">Down</button>
</div>
<div class="product_box">
<div class="item_name">Item Two</div>
<div class="product">0</div>
<button class="up category_one_up">Up</button>
<button class="down category_one_down">Down</button>
</div>
<div class="product_box">
<div class="item_name">Item Three</div>
<div class="product">0</div>
<button class="up category_one_up">Up</button>
<button class="down category_one_down">Down</button>
</div>
<div class="product_box">
<div class="item_name">Item Four</div>
<div class="product">0</div>
<button class="up category_two_up">Up</button>
<button class="down category_two_down">Down</button>
</div>
<div class="product_box">
<div class="item_name">Item Five</div>
<div class="product">0</div>
<button class="up category_three_up">Up</button>
<button class="down category_three_down">Down</button>
</div>
</div>
<div id="cart_container">
<h3>Shopping Cart</h3>
<div class="catone_header"><h3>Category One</h3></div>
<div class="cart_product">
<div class="item_name">Item One</div>
<input type="text" class="cart_product_number" value="0" />
<button class="close">X</button>
</div>
<div class="cart_product">
<div class="item_name">Item Two</div>
<input type="text" class="cart_product_number" value="0" />
<button class="close">X</button>
</div>
<div class="cart_product">
<div class="item_name">Item Three</div>
<input type="text" class="cart_product_number" value="0" />
<button class="close">X</button>
</div>
<div class="cattwo_header"><h3>Category Two</h3></div>
<div class="cart_product">
<div class="item_name">Item Four</div>
<input type="text" class="cart_product_number" value="0" />
<button class="close">X</button>
</div>
<div class="catthree_header"><h3>Category Three</h3></div>
<div class="cart_product">
<div class="item_name">Item Five</div>
<input type="text" class="cart_product_number" value="0" />
<button class="close">X</button>
</div>
</div>
</div><!-- end #body_container -->
JS
$(document).ready(function() {
var num;
var catone = 0;
var cattwo = 0;
var catthree = 0;
$('.up').click(function() {
num = parseInt($(this).siblings('.product').text());
console.log(num);
$(this).prevAll('.product').text(num + 1);
$('.cart_product').eq($(this).closest('.product_box').index()).fadeIn('slow').find('.cart_product_number').val(num + 1);
});
$('.down').click(function() {
num = parseInt($(this).siblings('.product').text());
if (num > 0) {
$(this).siblings('.product').text(num - 1);
};
if (parseInt($(this).siblings('.product').text()) === 0) {
$('.cart_product').eq($(this).closest('.product_box').index()).fadeOut('slow');
} else {
$('.cart_product').eq($(this).closest('.product_box').index()).show().find('.cart_product_number').val(num - 1);
}
});
// Category One
$('.category_one_up').click(function() {
catone++;
if (catone > 0) {
$('.catone_header').fadeIn('slow');
};
});
$('.category_one_down').click(function() {
if (catone > 0) {
catone--;
if (catone <= 0) {
$('.catone_header').fadeOut('slow');
};
};
});
// Category Two
$('.category_two_up').click(function() {
cattwo++;
if (cattwo > 0) {
$('.cattwo_header').fadeIn('slow');
};
});
$('.category_two_down').click(function() {
if (cattwo > 0) {
cattwo--;
if (cattwo <= 0) {
$('.cattwo_header').fadeOut('slow');
};
};
});
// Category Three
$('.category_three_up').click(function() {
catthree++;
if (catthree > 0) {
$('.catthree_header').fadeIn('slow');
};
});
$('.category_three_down').click(function() {
if (catthree > 0) {
catthree--;
if (catthree <= 0) {
$('.catthree_header').fadeOut('slow');
};
};
});
$('.close').click(function() {
$(this).parent('div.cart_product').fadeOut('slow');
$(this).prev('.cart_product_number').val(0);
});
});