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

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

vue實現購物車的小練習

瀏覽:44日期:2022-10-17 13:58:40

今天從網上找了一個購物車的小例子,照著敲了一下,收獲不少。下面的用一個小動圖展示一下成果:

vue實現購物車的小練習

接下來上代碼:

<!DOCTYPE html><html> <head> <meta charset='UTF-8'> <link href='http://m.b3g6.com/bcjs/css/shoppingcart.css' rel='stylesheet' type='text/css' /> <title></title> </head> <body> <div id='app'> <h2>購物清單</h2> <div class='nav'> <div><span v-bind: @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 v-bind: @click='item.isSelect=!item.isSelect'></span></td> <td> <div > <img v-bind:src=’item.gimg’ /> <div> <h3>{{item.gname}}</h3> <span>{{item.gbrand}} &nbsp;&nbsp;{{item.gplace}}</span><br /> <span>{{item.gpurity}} &nbsp;&nbsp;{{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='https://cdn.jsdelivr.net/npm/vue/dist/vue.js'></script> <script> var vm=new Vue({ el:’#app’, data:{ goods:[ {gname:’佳潔士美白牙膏’, gbrand:’品牌:佳潔士’, gplace:’產地:上海’, gpurity:’規格:120g’, gminnum:’起訂量:10件’, gstore:’倉庫地:上海滄海倉儲’, gprice:’800’, gimg:’img/good.jpg’, gnum:’3’, isSelect:false, }, {gname:’佳潔士美白牙膏’, gbrand:’品牌:佳潔士’, gplace:’產地:上?!? gpurity:’規格:120g’, gminnum:’起訂量:10件’, gstore:’倉庫地:上海滄海倉儲’, gimg:’img/good.jpg’, gprice:’400’, gnum:’5’, isSelect:false, } ] }, computed:{ //實時判斷是否全選 ifAllselect:function(){ var all; for(var i=0;i<this.goods.length;i++){ if(this.goods[i].isSelect==false){ all=false; break; } all=true; } return all; }, //獲取總件數和總金額數 getTotal:function(){ var num= 0 ; var allprice=0; for(var i=0;i<this.goods.length;i++){ if(this.goods[i].isSelect==true){ num=parseInt(num)+parseInt(this.goods[i].gnum); allprice=allprice+this.goods[i].gnum*this.goods[i].gprice; } } return{num:num,allprice:allprice} } }, methods:{ //全選或者取消全部選中 allSelect:function(ifAllselect){ for(var i=0;i<this.goods.length;i++){ this.goods[i].isSelect=!ifAllselect; } }, //刪除單個商品 deleteSingle:function(index){ if(this.goods[index].isSelect==true) this.goods.splice(index,1); else alert(’請選擇您要刪除的商品!’); }, //刪除選中的商品 deleteSel:function(){ this.goods=this.goods.filter(function(item){return !item.isSelect}) } } }) </script></html>

*{ 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
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
日本亚洲最大的色成网站www| 日韩精品三级| 国产精品igao视频网网址不卡日韩| 伊人久久亚洲| 蜜臀av性久久久久蜜臀aⅴ流畅| 午夜在线观看免费一区| 中文国产一区| 美女网站久久| 精品在线99| 午夜久久一区| 亚洲综合不卡| 亚洲欧美专区| 欧美日韩中出| 欧美国产日韩电影| 久久久国产精品网站| 成人在线超碰| 在线观看精品| 免费国产自久久久久三四区久久| 亚洲成人三区| 模特精品在线| 日韩欧美中文字幕电影| 欧美一区=区三区| 国产欧美另类| 精品丝袜久久| 在线看片国产福利你懂的| 黑人精品一区| 99久久亚洲精品蜜臀| 黄色亚洲大片免费在线观看| 午夜在线视频观看日韩17c| 亚洲三级视频| 国产日韩免费| 日韩国产一区二区| 在线一区免费观看| 日本在线观看不卡视频| 欧美激情99| 亚洲成人va| 另类亚洲自拍| 国产日产精品_国产精品毛片 | 亚洲精品成人一区| 18国产精品| 国产精品毛片久久| 日韩视频精品在线观看| 日本一不卡视频| 日韩av在线中文字幕| 亚洲91精品| 亚洲免费观看高清完整版在线观| 国产精品久久| 欧美高清一区| 日本高清久久| av不卡免费看| 国产精品一区二区三区四区在线观看| 高清在线一区| 影音先锋久久| 国产精品流白浆在线观看| 亚洲va中文在线播放免费| 国产婷婷精品| 美女视频一区在线观看| 日韩精品首页| 日本成人在线网站| 色乱码一区二区三区网站| 亚洲激情黄色| 麻豆91小视频| 久久xxxx精品视频| 国产精品二区不卡| 中文字幕亚洲影视| 日韩高清欧美| 日韩国产精品久久久久久亚洲| 国产精品久久观看| 伊人精品久久| 午夜av成人| 97精品资源在线观看| 久久婷婷亚洲| 国产精品久久久久久av公交车| 99精品一区| 91成人在线| 国产一区清纯| 免费视频一区二区三区在线观看| 99在线精品视频在线观看| 欧美国产极品| 蜜桃一区二区三区在线观看| 国产h片在线观看| 亚洲毛片一区| 激情视频一区二区三区| 国产精品中文字幕亚洲欧美| 亚洲精品2区| 久久久久黄色| 婷婷精品在线| 国精品一区二区| 高清一区二区| 88久久精品| 国产一区日韩一区| 国产福利91精品一区二区| 午夜性色一区二区三区免费视频| 久久国产毛片| 国产一区二区三区网| 日韩国产一二三区| 先锋影音国产一区| 国产麻豆久久| 久久三级中文| 亚洲美女91| 久久成人亚洲| 亚洲激情中文| 婷婷激情一区| 四虎国产精品免费观看| 青青草91视频| 亚洲精品1区2区| 色吊丝一区二区| 国产一区二区三区91| 国产亚洲人成a在线v网站| 喷白浆一区二区| 香蕉精品视频在线观看| 性欧美videohd高精| 六月丁香综合在线视频| 欧美日韩亚洲一区在线观看| 天堂俺去俺来也www久久婷婷| 亚洲一区免费| 亚洲精品在线观看91| 日韩免费看片| 成人免费一区| 国产一区二区三区四区五区| 欧美日韩伊人| 欧美中文一区| 视频一区中文字幕精品 | 欧美/亚洲一区| 国产成人精品一区二区三区免费| 国产精品一二| 国产精品资源| 久久av偷拍| 精品一区二区三区中文字幕在线| 欧美黑人巨大videos精品| 国产欧美在线观看免费| 日韩国产欧美在线播放| 日本不卡视频在线观看| 日韩在线一区二区| 麻豆成人在线| 亚洲欧洲日韩精品在线| 日本亚洲不卡| 久久精品99国产国产精| 国产精品视频一区二区三区| 国产精品99久久久久久董美香| 麻豆国产精品一区二区三区| 美女视频黄 久久| av资源中文在线天堂| 午夜精品成人av| 欧美在线亚洲| 少妇精品久久久| 国产剧情一区二区在线观看| 高清精品久久| 日本久久成人网| 亚洲一区国产一区| 日韩二区三区四区| 美女av一区| 亚洲啊v在线| 亚洲电影有码| 在线成人动漫av| 快she精品国产999| 中文字幕亚洲影视| 欧美精品99| 精品日本视频| 日韩久久电影| 模特精品在线| 亚洲精品日本| 日韩国产一区二| 综合色就爱涩涩涩综合婷婷| 欧美在线看片| 久久av国产紧身裤| 日本一二区不卡| 人人精品亚洲| 亚洲激精日韩激精欧美精品| 日本精品在线播放| 国产免费av国片精品草莓男男| 国产亚洲一区二区三区啪| 国产欧美一区二区色老头| 国产精品22p| 99精品视频在线观看免费播放| 国产在线欧美| 国产精品三上| 日本不卡高清视频| 久久国产三级精品| 色婷婷色综合| 久久婷婷一区| 视频精品一区二区| 日本va欧美va精品| 色在线中文字幕| 夜夜精品视频| 日本综合视频| 久久精品国产亚洲一区二区三区| 精品资源在线| 久久国产精品久久w女人spa| 日本色综合中文字幕| 久久99精品久久久野外观看| 亚洲欧洲高清| 91精品日本| 久久久久久亚洲精品美女| 婷婷综合六月| 久久av在线| 久久精品99国产精品日本| 欧美a级片一区| 色8久久久久| 荡女精品导航|