功能介绍
金额 = 单价 * 数量
金额会自动根据数量的变化进行变化,我们可以点击按钮增加或减少商品的数量。- 合计金额:只有在序号列号勾选上才会被计入总金额中,金额总数会根据用户的操作自动更新数据。
- 删除:如图我们勾选了第2个商品,当我们点击删除时,只会删除被选中的产品。
- 全选:点击1次全选会选中所有商品,第2次点击时就会取消已经选中的商品。
- 添加:用户可以自己添加商品、商品的单价、数量
代码
表头
<!-- 表头 -->
<tr style="font-weight: 800;">
<td>序号</td>
<td>商品</td>
<td>单价(元)</td>
<td>数量</td>
<td>金额(元)</td>
</tr>
商品表
- 点击增加或减少会调用方法函数,改变商品的数量
- 商品数量采用input,使用
v-model
实时变化商品的数量,用户可以直接输入商品数量 - 金额会根据商品单价和数量自动进行变化
<!-- 商品表 -->
<tr v-for="(value,index) in list">
<td><input type="checkbox" v-model="value.checked"></td>
<td>
<img v-bind:src="value.src" alt="图片" id="commodityImg">
<span>{{value.name}}</span>
<span style="font-size: 0.8em; color: #919191;">{{value.introduce}}</span>
</td>
<td style="color: #e00000;">¥{{ value.price }}</td>
<td style="padding: 0 !important;">
<button @click="reduce(index)">-</button>
<input type="text" v-model="value.count">
<button @click="add(index)">+</button>
</td>
<!-- 金额会根据商品单价和数量自动进行变化 -->
<td style="color: #e00000;font-weight: 800;">¥{{value.price*value.count}}</td>
</tr>
添加商品
<!-- 添加商品 -->
<tr id="add">
<td></td>
<td><input type="text" v-model="push.name" placeholder="商品"></td>
<td><input type="text" v-model="push.price" placeholder="价格"></td>
<td><input type="text" v-model="push.count" placeholder="数量"></td>
<td><button id="push" @click="pushValue">添加</button></td>
</tr>
全选、删除、合计等操作
<!-- 全选、删除、合计等操作 -->
<tr>
<td colspan="2">
<div @click="selectAll" ><input type="checkbox" v-model="selectAllValue">全选</div>
<div @click="selectDel" > 删除</div>
</td>
<td colspan="3">
合计:<p style="color: #e00000;font-weight: 800;padding: 0.6em 0em; display: contents;">¥{{priceSums}}</p></td>
</tr>
数据源
data(){
return{
selectAllValue:1,
priceSums:0,
push:{
name:null,
price:null,
count:null,
prices:null,
},
list:[{
checked:'false',
name:'微信公众号',
src:'https://mp.weixin.qq.com/mp/qrcode?scene=10000004&size=102&__biz=MzkzMjE5OTMwOA==&mid=2247487964&idx=1&sn=f7474b00c99bb7017530e4fbffd0c62d&send_time=',
introduce:'扫码关注,和群友们一起交流学习',
price:9999,
count:2,
prices:null,
},
{
checked:'false',
name:'QQ交流群',
src:'',
introduce:'',
price:6666,
count:1,
prices:null,
},
{
checked:'false',
name:'MacBookPro',
src:'https://img10.360buyimg.com/n2/jfs/t1/203950/20/28591/140129/637ca996E10cf6f5c/bb31749afd714364.jpg',
introduce:'',
price:21488,
count:1,
prices:null,
}],
}
},
computed计算属性,根据金额列的变化而变化
计算属性是基于它们的响应式依赖进行缓存的,只在相关响应式依赖发生改变时它们才会重新求值。
computed:{
// 计算总和
priceSums:function(){
var sum = 0;
for(var i = 0; i != this.list.length; i++){
if(this.list[i].checked == true){
sum = sum + this.list[i].price * this.list[i].count;
}
}
return sum;
}
},
利用methods定义一些方法
methods:{
//减少物品个数
reduce:function(index){
this.list[index].count = this.list[index].count - 1;
if(this.list[index].count == -1){
this.list.splice(index,1)
}
},
// 增加物品个数
add:function(index){
this.list[index].count = this.list[index].count + 1;
},
// 添加新元素在购物车中
pushValue:function(){
console.log(this.push.name)
if(this.push.name == undefined) return 0;
for(var i=0; i<this.lsist.length; i++){
if(this.list[i].name == this.push.name){
alert("你已勾选此产品");
return 0;
}
}
this.list.push(this.push);
this.push = {name:'', price:null, count:null};
},
// 选中所有
selectAll:function(){
for(var i=0,j=0; i<this.list.length; i++){
if(this.list[i].checked == true){
if(i==j){
for(var k=0; k<this.list.length; k++){
this.list[k].checked = false;
}
this.selectAllValue = false;
return 0;
}
j++;
}
this.list[i].checked = true;
}
this.selectAllValue = true;
},
// 删除选中
selectDel:function(){
if(confirm("你确认要删除吗?","提示框 ")){
for(var i=0; i<this.list.length; i++){
if(this.list[i].checked == true){
this.list.splice(i,1);
}
}
}
}
}
公众号:小知识酷,回复“VueShoppingCart1”获取完整源码
标签:count,index,Vue,name,price,list,购物车,实例,null From: https://www.cnblogs.com/MrFlySand/p/17420265.html