日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

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

vue實現淘寶購物車功能

瀏覽:232日期:2022-06-12 10:52:08

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

淘寶購物車功能,效果如下圖

vue實現淘寶購物車功能

非常簡單的邏輯,沒有做代碼的封裝,代碼如下

<div class='list-container'> <div class='top-ops'><div> <img src='http://m.b3g6.com/static/images/HomeRecommendShopInfoAdress@2x.png' alt=''> <span>浙江省杭州市...</span></div><div class='ops'> <span v-if='cartStatus === ’account’' @click='cartStatus = ’edit’'>編輯商品</span> <span v-if='cartStatus === ’edit’' @click='cartStatus = ’account’'>完成</span></div> </div> <div class='paddingB200'> <div v-for='(item,index) in cartShops' :key='index'><div class='shop-name'> <label> <input type='checkbox' name='shopRadio' :value='item.productShopId' @click='shopCheck($event,cartShops)' class='disN'> <b></b> </label> <div> <div> <img src='http://m.b3g6.com/static/images/mall@2x.png' alt=''> <span class='name'>{{item.shopName}}</span> </div> <span> <img src='http://m.b3g6.com/static/images/jtxq@2x.png' alt=''> </span> </div></div><div v-for='(goods,goodsIndex) in item.detailLists' :key='goodsIndex'> <label> <input type='checkbox' name='goodRadio' :price='goods.price' :num='goods.number' :dataId='item.productShopId' :value='goods.cartDetailId' @click='goodsCkeck($event,item.detailLists,cartShops,item.productShopId)' class='disN'> <b></b> </label> <div class='middle'> <img :src='http://m.b3g6.com/bcjs/goods.reportImage' alt=''> <div> <p class='name'>{{goods.name}}</p> <p class='spec'>{{goods.specifications}}</p> <p class='tab'><img src='http://m.b3g6.com/static/images/lsspbq@2x.png' alt=''> </p> </div> </div> <div class='right'> <p class='price'>¥{{goods.price}}</p> <p class='num'>X{{goods.number}}</p> <p class='caculate'> <span @click='numDecrease(goods.number)'></span> <span class='beeforCacul'>{{goods.number}}</span> <span :num='goods.cartDetailId'>{{goods.number}}</span> <span @click='numAdd(goods.number)'></span> </p> </div></div> </div> <div v-if='cartStatus === ’edit’'><label> <input type='checkbox' name='allRadio' @click='allCheck($event)'> <b></b> <span>全選</span></label><span class='delet'>刪除(3)</span> </div> <div v-if='cartStatus === ’account’'><label> <input type='checkbox' name='allRadio' @click='allCheck($event)'> <b></b> <span class='marginR40'>全選</span> <span>合計:</span> <span class='sum'>¥{{sumPrice.toFixed(2)}}</span></label><span @click='cauSum'>去結算({{totalNumber}})</span> </div> </div></div>

export default { components: { }, name: 'life', data() { return { cartStatus:'account', //購物車狀態,account結算,edit刪除編輯狀態 cartShops: [], //店鋪列表 sumPrice:0, //合計金額 totalNumber: 0, //總數 shopList:[], //店鋪列表 goodsList:[], //商品列表 }; }, watch: { }, mounted() { this.getCartDetail(); }, methods: { //購物車列表 getCartDetail: function(){ this.$http.get('api/product/v1/getCartDetail').then( res => {if(res.data.code === 200){ //console.log(res.data.data) this.cartShops = res.data.data.cartShops;}else{ Toast(res.data.msg);} }).catch( error => {console.log(error) }) }, //商品選擇 goodsCkeck: function(event,goodsList,shopList,shopId){ //商品列表+-,店鋪是否checked(店鋪列表+-),全選是否checked var input = document.getElementsByTagName(’input’) if(event.currentTarget.checked){this.goodsList.push(String(event.currentTarget.value));//如果店鋪內所有商品全選,店鋪選中var newArr = this.goodsList;var tt = goodsList.every(function(itemValue){ return (newArr.indexOf(String(itemValue.cartDetailId)) != -1)})if(tt){ //店鋪內全選,店鋪checked,店鋪列表+ for(var i = 0;i<input.length;i++){ if(input[i].value == shopId){ input[i].checked = true; } } this.shopList.push(String(shopId)); //防止shopid是number類型造成麻煩 //如果所有店鋪都全選,則全選按鈕checked if(this.shopList.length === shopList.length){ //所有店鋪全選 for(var i = 0;i<input.length;i++){ if(input[i].name == ’allRadio’){input[i].checked = true; } } }} }else{//商品列表--this.goodsList.splice(this.goodsList.indexOf(event.currentTarget.value),1)//如果店鋪checked,則取消,店鋪列表--for(var i = 0;i<input.length;i++){ if(input[i].value == shopId){ if(input[i].checked){ input[i].checked = false; this.shopList.splice(this.shopList.indexOf(String(shopId)),1); //防止shopid是number類型造成麻煩 } } //任意一個不選,全選取消 if(input[i].name == ’allRadio’){ input[i].checked = false; }} } //計算總價和數量 this.caculate(); }, //店鋪選擇 shopCheck: function(event,shopList){ //店鋪選中則對應商品全選,否則全不選 //console.log(event.currentTarget) var input = document.getElementsByTagName(’input’) if(event.currentTarget.checked){//店鋪列表+,店鋪checked,店鋪內商品全checked,商品列表++//console.log(this.shopList)this.shopList.push(String(event.currentTarget.value));//店鋪內商品全checkedfor(var i = 0;i<input.length;i++){ if(input[i].getAttribute(’dataId’) == event.currentTarget.value){ //將沒有選中的checked,并加入列表,去重 if(!input[i].checked){ input[i].checked = true; //商品列表++ this.goodsList.push(String(input[i].value)) } }}//所有店鋪全選if(this.shopList.length === shopList.length){ for(var i = 0;i<input.length;i++){ if(input[i].name == ’allRadio’){ input[i].checked = true; } }} }else{//店鋪取消checked,店鋪列表--,店鋪內所有商品取消checked,商品列表--this.shopList.splice(this.shopList.indexOf(String(event.currentTarget.value)),1);//店鋪內所有商品取消checkedfor(var i = 0;i<input.length;i++){ if(input[i].getAttribute(’dataId’) == event.currentTarget.value){ input[i].checked = false; //商品列表-- this.goodsList.splice(this.goodsList.indexOf(input[i].value),1); } //任意一個不選,全選取消 if(input[i].name == ’allRadio’){ input[i].checked = false; }} } //計算總價和數量 this.caculate(); }, //所有全選 allCheck: function(event){ var input = document.getElementsByTagName(’input’) if(event.currentTarget.checked){//全選checked,所有店鋪checked,店鋪列表++,所有商品checked,商品列表++for(var i = 0;i<input.length;i++){ //去重 if(!input[i].checked){ input[i].checked = true; if(input[i].name == ’shopRadio’){ this.shopList.push(String(input[i].value)) } if(input[i].name == ’goodRadio’){ this.goodsList.push(String(input[i].value)) } }} }else{//全不選取消checked,店鋪全部取消checked,店鋪列表清空,所有商品取消checked,商品列表清空for(var i = 0;i<input.length;i++){ input[i].checked = false; this.shopList = []; this.goodsList = [];} } //計算總價和數量 this.caculate(); }, //計算總金額總數量 caculate: function(){ var input = document.getElementsByTagName(’input’); var newArr = []; for(var i = 0;i<input.length;i++){if(input[i].name == ’goodRadio’ && input[i].checked){ var num = input[i].parentNode.parentNode.children[2].children[2].children[2].innerHTML; newArr.push( { ’price’: input[i].getAttribute(’price’), ’num’: num } )} } this.totalNumber = newArr.length; //歸零 this.sumPrice = 0; for(var j = 0,len = newArr.length;j<len;j++){this.sumPrice += newArr[j].price * newArr[j].num; } }, //數量減小 numDecrease: function(num){ //如果當前input選中,則修改數量計算價格,如果當前input沒有選中,則修改數量不計算價格 var spanList = event.currentTarget.parentNode.children; for(var i = 0,len = spanList.length;i<len;i++){if(spanList[i].getAttribute('class') == ’beeforCacul’){ spanList[i].style.display = ’none’;}if(spanList[i].getAttribute('class') == ’cacul’){ spanList[i].style.display = ’block’; var caculNum = spanList[i].innerHTML; if(caculNum < 2){ Toast(’寶貝不能再少了哦’); }else{ caculNum -- spanList[i].innerHTML = caculNum; }} } if(event.currentTarget.parentNode.parentNode.parentNode.children[0].children[0].checked){this.caculate(); } }, //數量增加 numAdd: function(num){ var spanList = event.currentTarget.parentNode.children; //console.log(event.currentTarget.parentNode.children) for(var i = 0,len = spanList.length;i<len;i++){if(spanList[i].getAttribute('class') == ’beeforCacul’){ spanList[i].style.display = ’none’;}if(spanList[i].getAttribute('class') == ’cacul’){ spanList[i].style.display = ’block’; var caculNum = spanList[i].innerHTML; caculNum ++; spanList[i].innerHTML = caculNum;} } if(event.currentTarget.parentNode.parentNode.parentNode.children[0].children[0].checked){this.caculate(); } }, //去結算 cauSum:function(){ if(this.sumPrice === 0){Toast(’您還沒有選擇寶貝哦’); }else{this.$router.push(’/cart/order’) } }, }};

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

標簽: 淘寶
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产精品外国| 欧美精品1区| 91一区二区三区四区| 欧美日本二区| 亚洲深深色噜噜狠狠爱网站| 国产一区日韩一区| 欧美福利专区| 亚洲综合二区| 91精品尤物| 国产欧美日韩在线一区二区| 精品精品99| 久久激情婷婷| 亚洲综合欧美| 国产精品久久久久久久久免费高清 | 中文在线а√在线8| 韩国一区二区三区视频| 日韩久久视频| 久久视频精品| 鲁鲁在线中文| 欧美在线资源| 日韩国产成人精品| 日韩1区在线| 鲁大师影院一区二区三区| 亚洲三级在线| 日本一二区不卡| 午夜亚洲精品| 久久爱www.| 国产农村妇女精品一二区| 天堂成人免费av电影一区| 国产探花在线精品| 亚洲调教视频在线观看| 色综合视频一区二区三区日韩| 精品资源在线| 伊人久久亚洲| 国产在线|日韩| 欧美一区激情| 国产精品7m凸凹视频分类| 国产日韩欧美高清免费| 五月婷婷六月综合| 国内自拍视频一区二区三区| 欧美中文字幕| 日韩不卡免费高清视频| 国产精品成人自拍| 欧美在线资源| 国产成人免费| 国产亚洲高清一区| 久久国产成人| 在线日韩欧美| 国产资源在线观看入口av| 欧美啪啪一区| 日本午夜精品视频在线观看| 欧美特黄a级高清免费大片a级| 国产精品原创| 国产精品xx| 精品国产乱码| 久久精品毛片| 久久av网址| 欧美黄色一区二区| 日韩精品一区二区三区中文在线 | 国产精品88久久久久久| 国产精品九九| 国产调教精品| 国产精品久久| 欧美黑人做爰爽爽爽| 国产视频一区二| 97se亚洲| 日韩一区免费| 一级成人国产| 日韩av一区二区在线影视| 亚洲精品乱码久久久久久蜜桃麻豆 | 午夜精品成人av| 日本精品影院| 欧美日韩第一| 蜜臀久久久久久久| 日韩精彩视频在线观看| 国产精品一级在线观看| 国产精品一区2区3区| 欧美激情在线精品一区二区三区| 久久精品一区二区三区中文字幕| 精品久久电影| 欧美日韩四区| 日韩中文字幕| 久久三级毛片| 亚洲精品123区| 97久久亚洲| 偷拍精品精品一区二区三区| 中国女人久久久| 国产精品亚洲综合久久| 日韩理论片av| 亚洲久草在线| se01亚洲视频| 日韩精品欧美精品| 国内一区二区三区| 亚洲深夜福利| 精品国产鲁一鲁****| 亚洲一区亚洲| 精品五月天堂| 伊人久久亚洲| 日韩不卡视频在线观看| 日韩高清在线一区| 欧美一级精品| 国产精品videossex| 午夜久久黄色| 国产精品蜜芽在线观看| 日韩一区网站| 日韩亚洲精品在线| 国产激情在线播放| 蜜桃视频在线观看一区二区| 国产精品成人a在线观看| 欧美中文日韩| 欧美~级网站不卡| 高清一区二区| 国产亚洲欧美日韩精品一区二区三区 | 亚洲美女久久| 亚洲激情国产| 欧美日韩在线观看视频小说| 卡一卡二国产精品| 69精品国产久热在线观看| 亚洲欧美日韩高清在线| 日韩大片在线播放| av中文字幕在线观看第一页| 国产精品玖玖玖在线资源| 久久aⅴ国产紧身牛仔裤| 免费av一区| 久久在线电影| 久久天堂成人| 亚洲午夜一级| 亚洲手机视频| 亚洲女人av| 在线日韩成人| 丝袜美腿亚洲一区| 亚洲国产不卡| 久久亚洲国产精品一区二区| 不卡中文一二三区| 蜜桃视频欧美| 日韩精品一二三区| 亚洲+小说+欧美+激情+另类| 亚洲精品乱码| 欧美精品国产白浆久久久久| 日韩国产欧美在线视频| 91成人在线网站| 国产精品magnet| bbw在线视频| 欧美日韩国产综合网| 亚洲免费成人av在线| 国产日韩一区二区三区在线播放 | 免费高潮视频95在线观看网站| 久久精品国产99国产精品| 精品久久一区| 黑丝美女一区二区| 日韩福利视频一区| 国产中文在线播放| 亚洲精品高潮| 久久精品亚洲| 一区二区自拍| 国产精品视频一区二区三区四蜜臂| 成人国产精品| 日韩三区四区| 欧美日韩在线观看首页| 在线亚洲国产精品网站| 国产午夜精品一区在线观看| 综合日韩av| 丝袜脚交一区二区| 精品香蕉视频| 欧美一区激情| 婷婷丁香综合| 久久精品资源| 日本国产亚洲| 中文精品在线| 久久精品播放| 精品国产精品久久一区免费式| 久久亚洲欧美| 亚洲欧美伊人| 国产精品久久久久久久久妇女| 日韩不卡一区二区| 中文字幕一区二区精品区| 亚洲欧洲美洲av| 国产乱码精品| 亚洲精一区二区三区| 一区二区自拍| 久久裸体视频| 成人羞羞视频播放网站| 国产精品亚洲四区在线观看| 日韩激情av在线| 日本午夜精品视频在线观看| 中文不卡在线| 伊人精品久久| 日韩高清不卡一区二区| 蜜臀精品一区二区三区在线观看 | 国产精品主播| 亚洲精品福利| 亚洲精品麻豆| 亚洲精品黄色| 日韩美女国产精品| 日韩精彩视频在线观看| 在线精品亚洲| 日本91福利区| 免费视频一区二区三区在线观看| 日本视频中文字幕一区二区三区| 亚洲精品影视|