這篇文章主要介紹vue如何實現購物車列表,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!
功能:
代碼:
<!DOCTYPE html>
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title></title>
<script src="./js/vue.js"></script>
</head>
<body>
<div id="app">
篩選:<input type="text" v-model="key">
<table border="1" cellspacing="0" cellpadding="10">
<tr>
<th>
<input type="checkbox" v-model="all" @change="checkAll()" >
</th>
<th>id</th>
<th>書籍名稱</th>
<th>出版日期</th>
<th>購買價格</th>
<th>數量</th>
<th>操作</th>
</tr>
<tr v-for="(item,index) in flist" :key="item.id">
<td ><input type="checkbox" v-model="item.sel" ></td>
<td>{{item.id}}</td>
<td>{{item.name}}</td>
<td>{{item.time}}</td>
<td>{{item.price|prices}}</td>
<td><button @click="item.num--" :disabled="item.num==1">-</button>{{item.num}}<button @click="item.num++">+</button></td>
<td><button @click="delItem(item.id)">移除</button></td>
</tr>
<tr><td colspan="7">總價格:{{total.price|prices}} 選擇數量:{{total.num}}</td></tr>
</table>
</div>
<script>
var vm = new Vue({
el:"#app",
data:{
key:"",
all:true,
list:[
{id:1,name:"小紅書",time:"2018-8",price:188.99,num:1,sel:true},
{id:2,name:"小爛熟",time:"2019-8",price:88.9,num:1,sel:true},
{id:3,name:"小綠樹",time:"2017-5",price:133.00,num:1,sel:true},
{id:4,name:"發生的樹",time:"2020-1",price:68.80,num:1,sel:true},
{id:5,name:"奧古",time:"2015-4",price:555.50,num:1,sel:true },
]
},
methods:{
delItem(item){
var falg=window.confirm("確定要刪除嗎?");
if(falg){
this.list.splice(item-1,1)
}
},
checkAll(){
this.list.forEach(item=>item.sel=this.all)
}
},
watch:{
list:{
handler:function(){
this.all=this.list.every(item=>item.sel)
},
deep:true
}
},
computed:{
total:function(){
var price=0;
var num=0;
this.list.forEach(item=>{
if(item.sel){
price+=item.num*item.price
num+=item.num*1
}
})
return ({price,num})
},
flist:function(){
if(this.key===''){return this.list}
return this.list.filter(item=>item.name.includes(this.key))
}
},
filters:{
prices:function(val,fix=2){
val=val.toFixed(fix)
val=""+val
return "¥"+val
}
},
})
</script>
</body>
</html>以上是vue如何實現購物車列表的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。