亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

vue實現購物車功能(商品分類)

瀏覽:13日期:2023-01-25 18:40:26

本文實例為大家分享了vue實現購物車功能的具體代碼,供大家參考,具體內容如下

new Vue({ el: '#app', data: { cIndex: 0, lists: [ { title: '推薦商品', goods: [ { id: 0, img: ’./images/goods.png’, name: ’散稱櫻桃1’, price: ’10.00’, num: 0 }, { id: 1, img: ’./images/goods.png’, name: ’散稱櫻桃1’, price: ’10.00’, num: 0 } ] }, { title: '推薦商品', goods: [ { id: 2, img: ’./images/goods.png’, name: ’散稱櫻桃2’, price: ’20.00’, num: 0 }, { id: 3, img: ’./images/goods.png’, name: ’散稱櫻桃2’, price: ’20.00’, num: 0 }, ] }, ], carArr: [], appearCar: false, }, computed:{ alltotal:function () { var alltotal = 0; var allNum = 0; for(var i = 0,len = this.lists.length;i<len;i++){ for(var j = 0,goodsLen = this.lists[i].goods.length;j<goodsLen;j++){ alltotal += parseInt(this.lists[i].goods[j].num)*parseFloat(this.lists[i].goods[j].price); allNum += parseInt(this.lists[i].goods[j].num); } } return [alltotal,allNum] }, }, methods: { leftTap: function (index) { this.cIndex = index }, showCar: function () { if (this.carArr.length == 0) { this.appearCar = false } else { this.appearCar = !this.appearCar } }, //商品數量加 addNum: function (data) { data.num++; var carArr = this.carArr; var isCar = false; if (carArr == 0) { carArr.push(data) } for (var i = 0, len = carArr.length; i < len; i++) { if (data.id == carArr[i].id) { isCar = true } } if (!isCar) { carArr.push(data) } }, reduceNum: function (data) { if (data.num <= 0) return; var carArr = this.carArr; data.num--; var isCar = false; for (var i = 0, len = carArr.length; i < len; i++) { if (carArr[i].num <= 0) { carArr.splice(i, 1) } } }, carAddNum: function (index) { this.carArr[index].num++ }, carReduceNum: function (index) { this.carArr[index].num--; if (this.carArr[index].num <= 0) { this.carArr.splice(index, 1) } if (this.carArr.length == 0) { this.appearCar = !this.appearCar } }, // 清空 delCar: function () { confirm(’確定清空購物車嗎?’); var cur = this.cIndex; var goods = this.lists[cur].goods if (true) { this.carArr = []; this.appearCar = !this.appearCar; for(var i = 0,len = this.lists.length;i<len;i++){ for(var j = 0,goodsLen = this.lists[i].goods.length;j<goodsLen;j++){ this.lists[i].goods[j].num=0; } } } }, Settlement:function () { if(this.alltotal[0]<=0){ console.log(’我不動’) }else{ window.location.href = ’cashierPay.html’ } } }})

html頁面

<div v-cloak> <div class=’box’> <div class=’boxleft’> <div class=’boxla’> <img src=’./images/sm.png’/> <span>掃碼</span> </div> <ul class=’boxlbox’> <template v-for='(item,index) in lists'> <li @click=’leftTap(index)’ : class=’boxlb’> <span class=’boxlb_inner’ :class='{boxlb_inner_cheak:cIndex==index}'>{{item.title}}</span> </li> </template> </ul> </div> <ul class=’boxright’> <li class=’boxri’ v-for='(item,index) in lists[cIndex].goods'> <img class=’boxri_img’ :src=’item.img’/> <div class=’boxri_text’> <div class=’boxrit_left’> <p class=’boxritl_name’>{{item.name}}</p> <p class=’boxritl_price’>¥{{item.price}}</p> </div> <div class=’boxrit_right’> <img @click=’reduceNum(item)’ v-show='item.num>0' class=’boxrit_right_img’ src=’./images/minus.png’/> <span class=’boxrit_right_num’ v-show='item.num>0'>{{item.num}}</span> <img @click=’addNum(item)’ class=’boxrit_right_img’ src=’./images/add.png’/> </div> </div> </li> </ul> </div> <footer class=’footer’> <div class=’cartImgBox’> <img class=’cartImg’ src=’./images/car.png’ @click=’showCar’/> 共{{alltotal[1]}}件商品 </div> <div class=’footerb’>¥{{alltotal[0]}}</div> <div @click=’Settlement’ class=’footerc’>結算</div> </footer> <!-- 購物車 --> <div class=’shop-car-mask’ v-show='appearCar'> <div class=’shop-com’> <div class=’shop-title’> <span>已選商品</span> <span @click='delCar'>清空</span> </div> <ul class='car-shopList'> <template v-for=’(item,index) in carArr’> <li class=’car-list’> <div class=’car-img’> <img :src=’item.img’/> </div> <div class=’car-name’>{{item.name}}</div> <div class=’car-num’>¥{{item.price}}</div> <div class=’boxrit_right2’> <img @click=’carReduceNum(index)’ class=’boxrit_right_img2’ src=’./images/minus.png’/> <span class=’boxrit_right_num2’>{{item.num}}</span> <img @click=’carAddNum(index)’ class=’boxrit_right_img2’ src=’./images/add.png’/> </div> </li> </template> </ul> </div> </div></div>

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Vue
相關文章:
主站蜘蛛池模板: 日韩欧美国产精品第一页不卡 | 九九免费精品视频在这里 | 纯欧美一级毛片_免费 | 在线 中文字幕 日韩 欧美 | 特黄特黄一级高清免费大片 | 成人免费一级毛片在线播放视频 | 色射影院 | 亚洲v视频| 在线观看国产视频 | 日韩欧美国产中文 | 国产97色在线 | 免费 | 特级全黄一级毛片免费 | 亚洲欧美激情综合首页 | 涩涩色中文综合亚洲 | 麻豆视传媒短视频网站链接 | 欧美丰满丝袜videossex | 一级做a爰片久久毛片免费看 | 六月久久 | 国自产拍在线视频天天更新 | 高h喷水荡肉爽文各种场合 高h辣肉各种姿势爽文bl | 9ⅰ视频在线播放 | 国产成+人+综合+亚洲不卡 | 中文字幕一区在线播放 | 日韩a级在线 | 亚洲第一大网站 | 三级黄色免费网站 | 午夜性刺激免费视频 | 黄在线观看 | 爽爽影院色黄网站在线观看 | 成人免费一级毛片在线播放视频 | 久久久国产精品网站 | 国产婷婷色| 九九精品视频在线观看 | 无遮挡高清一级毛片免费 | 久久久青草青青国产亚洲免观 | 日本久草视频 | 午夜看一级特黄a大片黑 | 麻豆传媒地址 | 高清性色生活片免费视频软件 | 国产一级毛片亚洲久留木玲 | 国产三级自拍 |