本文实例为大家分享了vue实现淘宝购物车的具体代码,供大家参考,具体内容如下
淘宝购物车功能,效果如下图
非常简单的逻辑,没有做代码的封装,代码如下
<div class="list-container"> <div class="top-ops"> <div> <img src="/UploadFiles/2021-04-02/HomeRecommendShopInfoAdress@2x.png">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)); //店铺内商品全checked for(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); //店铺内所有商品取消checked for(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') } }, } };以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
华山资源网 Design By www.eoogi.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
华山资源网 Design By www.eoogi.com
暂无评论...
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?
更新日志
2024年11月19日
2024年11月19日
- 黑鸭子2008-男人女人[首版][WAV+CUE]
- 张佳佳 《FOLK SONG Ⅱ Impromptus OP.23(即兴曲7首)》[320K/MP3][98.71MB]
- 祖海 《我家在中国 (维也纳金色大厅独唱音乐会)》[320K/MP3][118.55MB]
- 祖海 《我家在中国 (维也纳金色大厅独唱音乐会)》[FLAC/分轨][268.08MB]
- 张信哲.1996-思念【EMI百代】【WAV+CUE】
- 江美琪.2024-圆的?圆的>华纳】【FLAC分轨】
- 许巍.2018-无尽光芒【和雅弘嘉】【WAV+CUE】
- 庆怜 CAELAN《THE HALF-BLOOD PRINCE 半血王子》[320K/MP3][65.72MB]
- 庆怜 CAELAN《THE HALF-BLOOD PRINCE 半血王子》[FLAC/分轨][378.53MB]
- Fine乐团《废墟游乐》[320K/MP3][105.13MB]
- 万山红.2009-花开原野万山红Vol.1-2【柏菲】2CD【WAV+CUE】
- 曾庆瑜1992-18首中英文经典全集[台湾派森][WAV整轨]
- 【上扬爱乐】群星-TheSoundsofLS35AVol.4情迷4【低速原抓WAV分轨】
- Fine乐团《废墟游乐》[Hi-Res][24bit 48kHz][FLAC/分轨][767.04MB]
- Cicada《回返 (十五周年自选集)》[320K/MP3][93.87MB]