今天从网上找了一个购物车的小例子,照着敲了一下,收获不少。下面的用一个小动图展示一下成果:
接下来上代码:
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <link href="css/shoppingcart.css" rel="stylesheet" type="text/css" /> <title></title> </head> <body> <div id="app"> <h2>购物清单</h2> <div class="nav"> <div><span class="noselected" v-bind:class="{selected:ifAllselect}" @click="allSelect(ifAllselect)"></span>全选</div> <div>商品</div> <div>数量</div> <div>单价(元)</div> <div>金额(元)</div> <div>操作</div> </div> <table class="goods"> <tbody> <tr v-for="(item,index) in goods"> <td><span class="noselected" v-bind:class="{selected:item.isSelect}" @click="item.isSelect=!item.isSelect"></span></td> <td> <div class="good" > <img v-bind:src='item.gimg' /> <div> <h3>{{item.gname}}</h3> <span>{{item.gbrand}} {{item.gplace}}</span><br /> <span>{{item.gpurity}} {{item.gminnum}}</span><br /> <span>{{item.gstore}}</span> </div> </div> </td> <td><input type="number" v-model="item.gnum" min="0"/></td> <td><span>¥{{item.gprice}}</span></td> <td><span>¥{{item.gprice*item.gnum}}</span></td> <td><button @click="deleteSingle(index)">删除</button></td> </tr> </tbody> </table> <div class="footer"> <button @click="deleteSel">删除所选商品</button> <button>继续购物</button> <span><span>{{getTotal.num}}</span>件商品(不含运费)总计:<span>¥{{getTotal.allprice}}</span></span> <button>去结算</button> </div> </div> </div> </body> <script src="/UploadFiles/2021-04-02/vue.js">*{ padding: 0; margin: 0; } html,body{ width: 100%; overflow-x:hidden ; } #app{ width: 90%; margin: 50px auto; border: 1px solid gainsboro; border-top: none; } h2{ display: block; border-top: 4px solid dodgerblue; font-size: 17px; padding-left: 20px; line-height: 50px; color: dodgerblue; } .nav{ width: 100%; height: 40px; border:1px solid gainsboro ; border-left:none ; border-right: none; } .nav>div{ height: 100%; float: left; display: flex; justify-content: center; align-items: center; } .nav div:nth-child(1){ width: 15%; } .nav div:nth-child(2){ width:37%; } .nav div:nth-child(3){ width: 12%; } .nav div:nth-child(4){ width: 12%; } .nav div:nth-child(5){ width: 12%; } .nav div:nth-child(6){ width: 12%; } .noselected{ display: inline-block; width: 17px; height:17px; margin-right: 5px; background: url(../img/nocheck.png) no-repeat; background-size: contain; } .goods{ width: 100%; height: auto; } .goods tr{ width: 100%; } .goods tr td{ padding: 20px 0; } .goods tr>td:nth-child(1){ width: 17%; text-align: center; } .goods tr>td:nth-child(2){ width: 35%; } .goods tr>td:nth-child(3){ width: 12%; text-align: center; } .goods tr>td:nth-child(4){ width: 12%; text-align: center; } .goods tr>td:nth-child(5){ width: 12%; text-align: center; } .goods tr>td:nth-child(6){ width: 12%; text-align: center; } .good{ width: 100%; display: flex; align-items: center; } .good img{ width:120px; height: 120px; float: left; border: 2px solid gainsboro; margin-right: 30px; } .good>div{ font-size: 13px; line-height: 20px; } .good>div h3{ font-size: 11px; margin-bottom: 5px; } .goods input[type=number]{ width: 50px; } .goods tr td:nth-child(4),.goods tr td:nth-child(5){ color: red; } button{ cursor: pointer; border: none; outline: none; background-color: white; } .footer{ display: flex; align-items: center; width: 100%; height: 50px; background-color: #F7F7F7; position: relative; } .footer button{ border: none; background-color: #F7F7F7; font-size: 15px; } .footer button:nth-child(1){ margin-left: 30px; } .footer button:nth-child(2){ margin-left: 60px; } .footer button:nth-child(4){ height: 100%; position: absolute; right: 0; padding:0 20px; background-color: orange; } .footer>span{ position: absolute; right: 100px; } .footer>span span{ color: red; } .selected{ background: url(../img/check.png) no-repeat; background-size: contain; }以上为所有的html和css文件代码。
【总结】
1、computed:此处用computed主要有两个作用。一是判断是否全选。如果全选则添加selected这一class,如果没有则不添加;二是计算选择的总商品数和总金额。当用户更改商品数量时,总商品数和总金额也随之改变。
2、return返回两个值:第一次接触function里边return的值是两个这种情况,这种要通过对象的属性访问方法。例如:
function add(a,b){ var sum; var sub return{ sum:a+b, sub:a-b } } var obj = add(5,2); console.log(obj.sum); console.log(obj.sub);3、js的数组方法filter():
filter() 方法创建一个新的数组,新数组中的元素是通过检查指定数组中符合条件的所有元素。
注意: filter() 不会对空数组进行检测。
注意: filter() 不会改变原始数组。array.filter(function(currentValue,index,arr), thisValue)
- currentValue: 必须。当前元素的值
- index: 可选。当前元素的索引值
- arr:可选。当前元素属于的数组对象
- thisValue:可选。对象作为该执行回调时使用,传递给函数,用作 “this” 的值。如果省略了 thisValue ,“this” 的值为 “undefined”
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
标签:
vue,购物车
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
暂无“vue实现购物车的小练习”评论...
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。
更新动态
2024年12月26日
2024年12月26日
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]