电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

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

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

瀏覽:25日期: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
相關文章:
主站蜘蛛池模板: 快速门厂家批发_PVC快速卷帘门_高速门_高速卷帘门-广州万盛门业 快干水泥|桥梁伸缩缝止水胶|伸缩缝装置生产厂家-广东广航交通科技有限公司 | 冻干机(冷冻干燥机)_小型|实验型|食品真空冷冻干燥机-松源 | 美侍宠物-专注宠物狗及宠物猫训练|喂养|医疗|繁育|品种|价格 | 全自动真空上料机_粉末真空上料机_气动真空上料机-南京奥威环保科技设备有限公司 | 深圳富泰鑫五金_五金冲压件加工_五金配件加工_精密零件加工厂 | 登车桥动力单元-非标液压泵站-非标液压系统-深圳市三好科技有限公司 | 德国EA可编程直流电源_电子负载,中国台湾固纬直流电源_交流电源-苏州展文电子科技有限公司 | 成人纸尿裤,成人尿不湿,成人护理垫-山东康舜日用品有限公司 | 硫酸钡厂家_高光沉淀硫酸钡价格-河南钡丰化工有限公司 | 蓄电池在线监测系统|SF6在线监控泄露报警系统-武汉中电通电力设备有限公司 | 万家财经_财经新闻_在线财经资讯网 | 震动筛选机|震动分筛机|筛粉机|振筛机|振荡筛-振动筛分设备专业生产厂家高服机械 | 首页|专注深圳注册公司,代理记账报税,注册商标代理,工商变更,企业400电话等企业一站式服务-慧用心 | 缝纫客| 大功率金属激光焊接机价格_不锈钢汽车配件|光纤自动激光焊接机设备-东莞市正信激光科技有限公司 定制奶茶纸杯_定制豆浆杯_广东纸杯厂_[绿保佳]一家专业生产纸杯碗的厂家 | 商标转让-购买商标专业|放心的商标交易网-蜀易标商标网 | 冷轧机|两肋冷轧机|扁钢冷轧机|倒立式拉丝机|钢筋拔丝机|收线机-巩义市华瑞重工机械制造有限公司 | 齿式联轴器-弹性联轴器-联轴器厂家-江苏诺兴传动联轴器制造有限公司 | 上海办公室装修,写字楼装修—启鸣装饰设计工程有限公司 | 工控机,嵌入式主板,工业主板,arm主板,图像采集卡,poe网卡,朗锐智科 | 全自动烧卖机厂家_饺子机_烧麦机价格_小笼汤包机_宁波江北阜欣食品机械有限公司 | KBX-220倾斜开关|KBW-220P/L跑偏开关|拉绳开关|DHJY-I隔爆打滑开关|溜槽堵塞开关|欠速开关|声光报警器-山东卓信有限公司 | 刑事律师_深圳著名刑事辩护律师_王平聚【清华博士|刑法教授】 | 蔡司三坐标-影像测量机-3D扫描仪-蔡司显微镜-扫描电镜-工业CT-ZEISS授权代理商三本工业测量 | 香港新时代国际美容美发化妆美甲培训学校-26年培训经验,值得信赖! | 范秘书_懂你的范文小秘书 | 便携式表面粗糙度仪-彩屏硬度计-分体式粗糙度仪-北京凯达科仪科技有限公司 | 智慧钢琴-电钢琴-便携钢琴-数码钢琴-深圳市特伦斯乐器有限公司 | 首页|成都尚玖保洁_家政保洁_开荒保洁_成都保洁 | 儿童语言障碍训练-武汉优佳加感统文化发展有限公司 | 福兰德PVC地板|PVC塑胶地板|PVC运动地板|PVC商用地板-中国弹性地板系统专业解决方案领先供应商! 福建成考网-福建成人高考网 | 物联网卡_物联网卡购买平台_移动物联网卡办理_移动联通电信流量卡通信模组采购平台? | MES系统工业智能终端_生产管理看板/安灯/ESOP/静电监控_讯鹏科技 | 私人别墅家庭影院系统_家庭影院音响_家庭影院装修设计公司-邦牛影音 | 化妆品加工厂-化妆品加工-化妆品代加工-面膜加工-广东欧泉生化科技有限公司 | 超声波乳化机-超声波分散机|仪-超声波萃取仪-超声波均质机-精浩机械|首页 | 智慧钢琴-电钢琴-便携钢琴-数码钢琴-深圳市特伦斯乐器有限公司 | 耐破强度测试仪-纸箱破裂强度试验机-济南三泉中石单品站 | 等离子空气净化器_医用空气消毒机_空气净化消毒机_中央家用新风系统厂家_利安达官网 | 东莞螺杆空压机_永磁变频空压机_节能空压机_空压机工厂批发_深圳螺杆空压机_广州螺杆空压机_东莞空压机_空压机批发_东莞空压机工厂批发_东莞市文颖设备科技有限公司 | Dataforth隔离信号调理模块-信号放大模块-加速度振动传感器-北京康泰电子有限公司 |