<template>
<div class="home" v-cloak>
<div v-if="list.length">
<table>
<thead>
<tr>
<th></th>
<th>商品名称</th>
<th>商品单价</th>
<th>购买数量</th>
<th>操作</th>
</tr>
</thead>
<tbody>
<tr v-for="(item,index) in list" :key="index">
<td>
{{index + 1}}
</td>
<td>{{item.name}}</td>
<td>{{item.price}}</td>
<td>
<button @click="handleReduce(index)" :disabled="item.count === 1">-</button>
{{item.count}}
<button @click="handleAdd(index)">+</button>
</td>
<td>
<button @click="handleRemove(index)">移除</button>
</td>
</tr>
</tbody>
</table>
<div>总价:¥{{totalPrice}}</div>
</div>
<div v-else>购物车为空</div>
</div>
</template>
<script>
export default {
data() {
return {
list: [
{
id: 1,
name: "iphone 7",
price: 6188,
count: 1
},
{
id: 2,
name: "iphone 8",
price: 9800,
count: 1
},
{
id: 3,
name: "iphone 9",
price: 10021,
count: 1
}
],
message: "",
picked: true,
pick:'js',
};
},
computed: {
// 总价
totalPrice: function() {
var total = 0;
for (let i = 0; i < this.list.length; i++) {
// 把data中的每个list赋给iteM
const item = this.list[i];
// 把价格和数量相乘给到当前的总价
total += item.price * item.count;
}
// 把价格转成字符串,并使用正则后三们用,分开
return total.toString().replace(/\B(?=(\d{3})+$)/g, ",");
}
},
methods: {
// 减
handleReduce(index) {
if (this.list[index].count === 1) return;
this.list[index].count--;
},
// 加
handleAdd(index) {
this.list[index].count++;
},
// 移除
handleRemove(index) {
this.list.splice(index, 1);
},
// input时时更新
handleInput(e) {
this.message = e.target.value;
},
};
</script>
<style lang="less" scoped>
// 作用是取消数据绑定时出现的代码闪烁
[v-cloak] {
display: none;
}
table {
border: 1px solid #e9e9e9;
border-collapse: collapse;
border-spacing: 0;
// 隐藏表格中空单元格上的边框和背景:
empty-cells: show;
}
th,
td {
padding: 8px 16px;
border: 1px solid #e9e9e9;
text-align: left;
}
th {
background: #f7f7f7;
color: #5c6b77;
font-weight: 600;
white-space: nowrap;
}
.menu{
border: 1px solid #ccc;
}
</style>