vue 实现图书购物车小案例

<!DOCTYPE html>
<html>
 <head>
     <meta charset="UTF-8">
	 <title>tushu</title>
     <style>
	  .active{
		  color: red;
	  }
	  table{
		border: 1px solid #e9e9e9;
		border-collapse: collapse;
		border-spacing: 0;
	  }
	  th,td{
		padding: 8px 16px;
		border: 1px solid #e9e9e9;
		text-align: center;
	  }
	  th{
		background-color: #f7f7f7;
		color: #5c6b77;
		font-weight: 600;
	  }
     </style>
 </head>
 <body>
	 <div id="app">
		 <div v-if="books.length">
		 	 <table>
			 <thead>
				 <tr>
				     <th></th>
				     <th>书籍名称</th>
				     <th>出版日期</th>
				     <th>价格</th>
				     <th>购买数量</th>
				     <th>操作</th>
				 </tr>
			 </thead>
			 <tbody>
			     <tr v-for="(item,index) in books">
					 <td>{{item.id}}</td>
					 <td>{{item.name}}</td>
					 <td>{{item.date}}</td>
					 <td>{{item.price | shownd}}</td>
					 <td>
						 <button :disabled="item.count <= 1" @click="decream(index)">-</button>
						 {{item.count}}
						 <button @click="incream(index)">+</button>
					 </td>
				     <td><button @click="redis(index)">移除</button></td>
				 </tr>
			 </tbody>
		 </table>
			 <h2>总价格:{{zprice | shownd}}</h2>
		 </div>
		 <h1 v-else>购物车为空</h1>
	 </div> 
 
 <script src="../vue.js"></script>
 <script src="./main.js"></script>
 </body>
</html>

main.js代码:

const app = new Vue({
	el:'#app',
	data:{
		books:[
		    {
				id: 1,
				name: '《算法导论》',
				date: '2006-6',
				price: 85.00,
				count: 1
			},
			{
				id: 2,
				name: '《编程艺术》',
				date: '2006-5',
				price: 59.00,
				count: 1
			},
			{
				id: 3,
				name: '《编程珠玑》',
				date: '2008-10',
				price: 39.00,
				count: 1
			},
			{
				id: 4,
				name: '《代码大全》',
				date: '2006-3',
				price: 128.00,
				count: 1
			}
		]
	},
	methods:{
		incream(index){
            this.books[index].count++
		},
		decream(index){
			this.books[index].count--
		},
		redis(index){
			this.books.splice(index,1)
		}
	},
	computed:{
		zprice(){
			let st = 0
			for(let i=0; i<this.books.length;i++){
				st += this.books[i].price * this.books[i].count
			}
			return st
		}
	},
	filters:{
        shownd(price){
			return '¥' + price.toFixed(2)
		}
	}
})

在这里插入图片描述

  • 2
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值