您好,登錄后才能下訂單哦!
使用vue制作一個(gè)購物車功能,只是一個(gè)測試版本,注重的是功能實(shí)現(xiàn),界面并沒有做好,數(shù)據(jù)也是模擬數(shù)據(jù)等
不說那么多,直接上代碼
<template> <div id="app"> 全選<input type="checkbox" v-model="checkall" @change="check_all()"> <div v-for="(item,index) in mylist" :key="index"> <span>{{item.oname}}</span><input type="checkbox" v-model="item.this_all" @change="check_list(index)"> <p v-for="(goods,nindex) in item.newlist" :key="nindex"> <input type="checkbox" v-model="goods.check_one" @change="click_input(index,nindex)">{{goods.newname}}--{{goods.price}}元 </p> </div> <p>總價(jià):{{allprice}}</p> <button @click="btn()">提交訂單</button> </div> </template> <script> export default { name: 'App', data(){ return{ mylist:[ {oname:"第一個(gè)",this_all:true,newlist:[{newname:"籃球",check_one:true,price:600},{newname:"足球",check_one:true,price:200},{newname:"滑雪",check_one:true,price:150}]}, {oname:"第二個(gè)",this_all:true,newlist:[{newname:"西瓜",check_one:true,price:35},{newname:"桃子",check_one:true,price:20}]}, {oname:"第三個(gè)",this_all:true,newlist:[{newname:"英雄聯(lián)盟",check_one:true,price:200}]}, ], checkall:true, allprice:0, cpmylist:[] } }, mounted:function(){ this.money(); }, methods: { money:function(){ var that = this; this.allprice=0; that.mylist.forEach(item1 =>{ item1.newlist.forEach(item2 =>{ if(item2.check_one==true){ that.allprice+=item2.price; } }) }) }, check_all:function(){ var that = this; that.mylist.forEach(item1 => { item1.this_all=that.checkall item1.newlist.forEach(item2 => { item2.check_one=that.checkall }) }); that.money(); }, abc:function(){ var that = this; var aaa = that.mylist.filter(item2 =>{ return item2.this_all==true }) aaa.length==that.mylist.length ? that.checkall = true : that.checkall = false that.money(); }, check_list:function(i){ var that = this; that.mylist[i].newlist.forEach(item1 =>{ item1.check_one=that.mylist[i].this_all }) that.abc(); }, click_input:function(i,j){ var that = this; var checklist = that.mylist[i].newlist.filter(item1 =>{ return item1.check_one==true }) checklist.length==that.mylist[i].newlist.length ? that.mylist[i].this_all = true : that.mylist[i].this_all = false that.abc(); }, btn:function(){ var that = this; that.cpmylist=JSON.parse(JSON.stringify(that.mylist)); that.cpmylist.filter(item1 =>{ item1.newlist = item1.newlist.filter(item2 =>{ return item2.check_one==true }) }) that.cpmylist=that.cpmylist.filter(item3 =>{ return item3.newlist.length!=0 }) if(that.cpmylist.length==0){ alert("請(qǐng)選擇商品哦!") }else{ console.log("★★★您購買的商品是:"); that.cpmylist.forEach(item4 =>{ console.log("----------"+item4.oname+"店鋪----------"); item4.newlist.forEach(item5 =>{ console.log("——>:"+item5.newname); }) }) } } }, } </script> <style> #app { font-family: 'Avenir', Helvetica, Arial, sans-serif; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; text-align: center; color: #2c3e50; margin-top: 60px; } </style>
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持億速云。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。