购物车案例
案例:购物车案例模块-全选
- 全选思路:里面 3 个小的复选框按钮(j-checkbox)选中状态(checked)跟着全选按钮(checkall)走。
- 因为 checked 是复选框的固有属性,此时我们需要利用 prop() 方法获取和设置该属性。
- 把全选按钮状态赋值给 3 小复选框就可以了。
- 当我们每次点击小的复选框按钮,就来判断:
- 如果小复选框被选中的个数等于 3 就应该把全选按钮选上,否则全选按钮不选。
- :checked 选择器 :checked 查找被选中的表单元素。
JavaScript
/* 1. 全选 全不选功能模块 */
// 就是把全选按钮(checkall)的状态赋值给 三个小的按钮(j-checkbox)就可以了
// 事件可以使用change
$(".checkall").change(function () {
// console.log($(this).prop("checked"));
$(".j-checkbox, .checkall").prop("checked", $(this).prop("checked"));
if ($(this).prop("checked")) {
// 让所有的商品添加 check-cart-item 类名
$(".cart-item").addClass("check-cart-item");
} else {
// check-cart-item 移除
$(".cart-item").removeClass("check-cart-item");
}
});
/*2. 如果小复选框被选中的个数等于3 就应该把全选按钮选上,否则全选按钮不选。*/
$(".j-checkbox").change(function () {
// if(被选中的小的复选框的个数 === 3) {
// 就要选中全选按钮
// } else {
// 不要选中全选按钮
// }
// console.log($(".j-checkbox:checked").length);
// $(".j-checkbox").length 这个是所有的小复选框的个数
if ($(".j-checkbox:checked").length === $(".j-checkbox").length) {
$(".checkall").prop("checked", true);
} else {
$(".checkall").prop("checked", false);
}
if ($(this).prop("checked")) {
// 让当前的商品添加 check-cart-item 类名
$(this).parents(".cart-item").addClass("check-cart-item");
} else {
// check-cart-item 移除
$(this).parents(".cart-item").removeClass("check-cart-item");
}
});
案例:增减商品数量
- 核心思路:首先声明一个变量,当我们点击
+
号(increment),就让这个值++
,然后赋值给文本框。 - 注意1: 只能增加本商品的数量, 就是当前
+
号的兄弟文本框(itxt)的值。 - 修改表单的值是
val()
方法 - 注意2: 这个变量初始值应该是这个文本框的值,在这个值的基础上
++
。要获取表单的值 - 减号(decrement)思路同理,但是如果文本框的值是 1,就不能再减了。
javascript
// 3. 增减商品数量模块 首先声明一个变量,当我们点击 + 号(increment),就让这个值++,然后赋值给文本框。
$(".increment").click(function () {
// 3.1 修改数量
// 得到当前兄弟文本框的值
var n = $(this).siblings(".itxt").val();
// console.log(n);
n++;
$(this).siblings(".itxt").val(n);
// 3.2 计算小计模块 根据文本框的值 乘以 当前商品的价格 就是 商品的小计
// 当前商品的价格 p var p = $(this).parents('.p-num').siblings('.p-price').html();
// console.log(p);
p = p.substr(1);
console.log(p);
var price = (p * n).toFixed(2);
// 小计模块
// toFixed(2) 可以让我们保留2位小数
$(this)
.parents(".p-num")
.siblings(".p-sum")
.html("¥" + price);
getSum();
});
案例:修改商品小计
- 核心思路:每次点击
+
号或者-
号,根据文本框的值 乘以 当前商品的价格 就是 商品的小计 - 注意1: 只能增加本商品的小计, 就是当前商品的小计模块(p-sum)
- 修改普通元素的内容是 text() 方法
- 注意2: 当前商品的价格,要把
¥
符号去掉再相乘截取字符串 substr(1) parents('选择器')
可以返回指定祖先元素- 最后计算的结果如果想要保留2位小数 通过
toFixed(2)
方法 - 用户也可以直接修改表单里面的值,同样要计算小计。 用表单 change 事件
- 用最新的表单内的值 乘以单价即可 但是还是当前商品小计
JavaScript
/*3. 增减商品数量模块 首先声明一个变量,当我们点击+号(increment),就让这个值++,然后赋值给文本框。*/
$(".increment").click(function () {
// 得到当前兄弟文本框的值
var n = $(this).siblings(".itxt").val();
// console.log(n);
n++;
$(this).siblings(".itxt").val(n);
// 3. 计算小计模块 根据文本框的值 乘以 当前商品的价格 就是 商品的小计
// 当前商品的价格 p
var p = $(this).parents(".p-num").siblings(".p-price").html();
// console.log(p); ¥25.20 去掉第一个字符
p = p.substr(1);
console.log(p);
var price = (p * n).toFixed(2);
// 小计模块
// toFixed(2) 可以让我们保留2位小数
$(this).parents(".p-num").siblings(".p-sum").html("¥" + price);
getSum();
});
$(".decrement").click(function () {
// 得到当前兄弟文本框的值
var n = $(this).siblings(".itxt").val();
if (n == 1) {
return false;
}
// console.log(n);
n--;
$(this).siblings(".itxt").val(n);
// var p = $(this).parent().parent().siblings(".p-price").html();
// parents(".p-num") 返回指定的祖先元素
var p = $(this).parents(".p-num").siblings(".p-price").html();
// console.log(p);
p = p.substr(1);
console.log(p);
// 小计模块
$(this).parents(".p-num").siblings(".p-sum").html("¥" + (p * n).toFixed(2));
getSum();
});
案例:计算总计和总额
- 把所有文本框中的值相加就是总额数量,总计同理。
- 文本框里面的值不同,如果想要相加需要用 each() 遍历,声明一个变量做计数器,累加即可。
JavaScript
/*4. 用户修改文本框的值 计算 小计模块 */
$(".itxt").change(function () {
// 先得到文本框的里面的值 乘以 当前商品的单价
var n = $(this).val();
// 当前商品的单价
var p = $(this).parents(".p-num").siblings(".p-price").html();
// console.log(p);
p = p.substr(1);
$(this).parents(".p-num").siblings(".p-sum").html("¥" + (p * n).toFixed(2));
getSum();
});
/*5. 计算总计和总额模块*/
getSum();
function getSum() {
var count = 0; // 计算总件数
var money = 0; // 计算总价钱
$(".itxt").each(function (i, ele) {
count += parseInt($(ele).val());
});
$(".amount-sum em").text(count);
$(".p-sum").each(function (i, ele) {
money += parseFloat($(ele).text().substr(1));
});
$(".price-sum em").text("¥" + money.toFixed(2));
}
案例:删除商品模块
- 核心思路:把商品 remove() 删除元素即可
- 有三个地方需要删除: 1. 商品后面的删除按钮 2. 删除选中的商品 3. 清理购物车
- 商品后面的删除按钮: 一定是删除当前的商品,所以从
$(this)
出发 - 删除选中的商品: 先判断小的复选框按钮是否选中状态,如果是选中,则删除对应的商品
- 清理购物车: 则是把所有的商品全部删掉
javascript
// 6. 删除商品模块
// (1) 商品后面的删除按钮
$(".p-action a").click(function () {
// 删除的是当前的商品
$(this).parents(".cart-item").remove();
getSum();
});
// (2) 删除选中的商品
$(".remove-batch").click(function () {
// 删除的是小的复选框选中的商品
$(".j-checkbox:checked").parents(".cart-item").remove();
getSum();
});
// (3) 清空购物车 删除全部商品
$(".clear-all").click(function () {
$(".cart-item").remove();
getSum();
});
案例:选中商品添加背景
- 核心思路:选中的商品添加背景,不选中移除背景即可
- 全选按钮点击:如果全选是选中的,则所有的商品添加背景,否则移除背景
- 小的复选框点击: 如果是选中状态,则当前商品添加背景,否则移除背景
- 这个背景,可以通过类名修改,添加类和删除类