成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專(zhuān)欄INFORMATION COLUMN

小案例:運(yùn)用vue實(shí)現(xiàn)簡(jiǎn)單的購(gòu)物車(chē)

3403771864 / 556人閱讀

  有關(guān)ue的項(xiàng)目,今天為大家做一個(gè)小案例,就是把一個(gè)js的購(gòu)物車(chē)改成vue了

  css部分是直接引入的插件

  效果圖如下

  <template>
  <div class="head">
  <meta charset="UTF-8">
  <title>我的購(gòu)物車(chē)-品優(yōu)購(gòu)</title>
  <meta name="description" content="品優(yōu)購(gòu)JD.COM-專(zhuān)業(yè)的綜合網(wǎng)上購(gòu)物商城,銷(xiāo)售家電、數(shù)碼通訊、電腦、家居百貨、服裝服飾、母嬰、圖書(shū)、食品等數(shù)萬(wàn)個(gè)品牌優(yōu)質(zhì)商品.便捷、誠(chéng)信的服務(wù),為您提供愉悅的網(wǎng)上購(gòu)物體驗(yàn)!" />
  <meta name="Keywords" content="網(wǎng)上購(gòu)物,網(wǎng)上商城,手機(jī),筆記本,電腦,MP3,CD,VCD,DV,相機(jī),數(shù)碼,配件,手表,存儲(chǔ)卡,品優(yōu)購(gòu)" />
  <!-- &lt;!&ndash; 引入facicon.ico網(wǎng)頁(yè)圖標(biāo) &ndash;&gt;-->
  <!-- <link rel="shortcut icon" href="favicon.ico" rel="external nofollow" type="image/x-icon" />-->
  <!-- 引入css 初始化的css 文件 -->
  <link rel="stylesheet" href="src/assets/carStyle/base.css" rel="external nofollow" >
  <!-- 引入公共樣式的css 文件 -->
  <link rel="stylesheet" href="src/assets/carStyle/common.css" rel="external nofollow" >
  <!-- 引入car css -->
  <link rel="stylesheet" href="src/assets/carStyle/car.css" rel="external nofollow" >
  </div>
  <div class="body">
  <div class="car-header">
  <div class="w">
  <div class="car-logo">
  <img src="src/assets/images/logo.png" alt=""> <b>購(gòu)物車(chē)</b>
  </div>
  </div>
  </div>
  <div class="c-container">
  <div class="w">
  <div class="cart-filter-bar">
  <em>全部商品</em>
  </div>
  <!-- 購(gòu)物車(chē)主要核心區(qū)域 -->
  <div class="cart-warp">
  <!-- 頭部全選模塊 -->
  <div class="cart-thead">
  <div class="t-checkbox">
  <input type="checkbox" name="" id="" class="checkall"> 全選
  </div>
  <div class="t-goods">商品</div>
  <div class="t-price">單價(jià)</div>
  <div class="t-num">數(shù)量</div>
  <div class="t-sum">小計(jì)</div>
  <div class="t-action">操作</div>
  </div>
  <!-- 商品詳細(xì)模塊 -->
  <div class="cart-item-list" v-for="(good,index) in cartList">
  <div class="cart-item">
  <div class="p-checkbox">
  <input type="checkbox" v-model="good.isSelected" @click="oneSelected(index)">
  </div>
  <div class="p-goods">
  <div class="p-img">
  <img v-bind:src=good.imgUrl alt="">
  </div>
  <div class="p-msg">{{good.message}}</div>
  </div>
  <div class="p-price">{{good.PriceItem}}</div>
  <div class="p-num">
  <div class="quantity-form">
  <el-button class="increment" @click="changeDe(index)">-</el-button>
  <input type="text" class="itxt" v-model=good.ItemNum placeholder="1">
  <el-button class="increment" @click="changeIn(index)">+</el-button>
  </div>
  </div>
  <div class="p-sum">{{good.PriceSum}}</div>
  <div class="p-action">
  <el-button type="danger" @click="DeleteItem(id)">刪除</el-button>
  </div>
  </div>
  </div>
  <!-- 結(jié)算模塊 -->
  <div>
  <div>
  <input type="checkbox" @click="allCheck" v-model="allSelected">全選
  </div>
  <div>
  <a @click="DeleteSelected"> 刪除選中的商品</a>
  <a @click="DeleteAll">清理購(gòu)物車(chē)</a>
  </div>
  <div>
  <div>已經(jīng)選<em>{{NumSum}}</em>件商品</div>
  <div>總價(jià): <em>{{totalPrice}}</em></div>
  <div>去結(jié)算</div>
  </div>
  </div>
  </div>
  </div>
  </div>
  </div>
  </template>
  <script>
  import { defineComponent } from 'vue'
  export default defineComponent({
  data(){
  return{
  allSelected:false,
  cartList:[
  {
  imgUrl:'src/assets/upload/p1.jpg',
  message:'【5本26.8元】經(jīng)典兒童文學(xué)彩圖青少版八十天環(huán)游地球中學(xué)生語(yǔ)文教學(xué)大綱',
  PriceItem: 12.6,
  PriceSum: 12.6,
  ItemNum: 1,
  isSelected:false
  },
  {
  imgUrl:'src/assets/upload/p2.jpg',
  message:'【2000張貼紙】貼紙書(shū) 3-6歲 貼畫(huà)兒童 貼畫(huà)書(shū)全套12冊(cè) 貼畫(huà) 貼紙兒童 汽',
  PriceItem: 24.8,
  PriceSum: 24.8,
  ItemNum: 1,
  isSelected:false
  },
  {
  imgUrl:'src/assets/upload/p3.jpg',
  message:'唐詩(shī)三百首+成語(yǔ)故事全2冊(cè) 一年級(jí)課外書(shū) 精裝注音兒童版 小學(xué)生二三年級(jí)課外閱讀書(shū)籍',
  PriceItem: 29.8,
  PriceSum: 29.8,
  ItemNum: 1,
  isSelected:false
  },
  ]
  }
  },
  methods:{
  changeIn(id){
  let n=this.cartList[id].ItemNum;
  // console.log(n);
  this.cartList[id].ItemNum++;
  this.cartList[id].PriceSum = this.cartList[id].ItemNum * this.cartList[id].PriceItem;
  },
  changeDe(id){
  if(this.cartList[id].ItemNum === 0)alert("該商品已經(jīng)清0!");
  else {
  this.cartList[id].ItemNum--;
  this.cartList[id].PriceSum = this.cartList[id].ItemNum * this.cartList[id].PriceItem;
  }
  },
  DeleteItem(id){
  // console.log(this.$parent);
  // console.log(this.$children);
  this.cartList.splice(id,1);
  },
  allCheck(){
  // console.log(this.allSelected);
  this.cartList.forEach((item)=>{
  // console.log(this.allSelected);
  // console.log(this.cartList);
  item.isSelected=!this.allSelected;
  })
  },
  DeleteSelected(){
  for(let i=0;i<this.cartList.length;i++){
  if(this.cartList[i].isSelected===true){
  this.cartList.splice(i,1);
  }
  }
  },
  DeleteAll(){
  this.cartList.splice(0,this.cartList.length);
  },
  oneSelected(id){
  if(this.cartList[id].isSelected===false)
  this.cartList[id].isSelected=true;
  else
  this.cartList[id].isSelected=false;
  let n=0;
  for(let i=0;i<this.cartList.length;i++){
  if(this.cartList[i].isSelected===true)
  n++;
  }
  if(n===this.cartList.length)this.allSelected=true;
  else this.allSelected=false;
  }
  },
  computed:{
  NumSum() {
  let num=0;
  this.cartList.forEach((item)=>{
  if(item.isSelected===true)
  num++;
  })
  return num;
  },
  totalPrice() {
  let totalp=0;
  this.cartList.forEach((item)=>{
  if(item.isSelected===true)
  totalp += item.PriceSum;
  })
  return totalp;
  },
  }
  })
  </script>
  <style scoped>
  </style>


文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/128195.html

相關(guān)文章

  • 一些基于React、Vue、Node.js、MongoDB技術(shù)棧實(shí)踐項(xiàng)目

    摘要:利用中間件實(shí)現(xiàn)異步請(qǐng)求,實(shí)現(xiàn)兩個(gè)用戶(hù)角色實(shí)時(shí)通信。目前還未深入了解的一些概念。往后會(huì)寫(xiě)更多的前后臺(tái)聯(lián)通的項(xiàng)目。刪除分組會(huì)連同組內(nèi)的所有圖片一起刪除。算是對(duì)自己上次用寫(xiě)后臺(tái)的一個(gè)強(qiáng)化,項(xiàng)目文章在這里。后來(lái)一直沒(méi)動(dòng),前些日子才把后續(xù)的完善。 歡迎訪問(wèn)我的個(gè)人網(wǎng)站:http://www.neroht.com/? 剛學(xué)vue和react時(shí),利用業(yè)余時(shí)間寫(xiě)的關(guān)于這兩個(gè)框架的訓(xùn)練,都相對(duì)簡(jiǎn)單,有的...

    tangr206 評(píng)論0 收藏0
  • 智慧零售,騰訊云在下一盤(pán)很大

    摘要:這一消息,讓智慧零售成為新零售無(wú)界零售之后又一次點(diǎn)燃零售行業(yè)的希望之詞,同時(shí)也讓大家對(duì)騰訊云在智慧零售領(lǐng)域的默默耕耘感到震驚。3月9日,騰訊云計(jì)算(北京)有限公司(以下簡(jiǎn)稱(chēng)騰訊云)、星家加(母公司為深圳市啟明星電子商務(wù)有限公司)共同舉辦以共創(chuàng)智慧零售新未來(lái)為主題的簽約儀式,山東凌云集團(tuán)、長(zhǎng)沙通程集團(tuán)、南寧百貨、利群集團(tuán)、新疆友好集團(tuán)等眾多區(qū)域龍頭百貨零售企業(yè)參加了簽約儀式。根據(jù)合作協(xié)議,騰訊...

    Caicloud 評(píng)論0 收藏0
  • 學(xué)習(xí)Vue.js五個(gè)例子

    摘要:前言最近在學(xué)習(xí),學(xué)著寫(xiě)了幾個(gè)小例子,自己記錄一下,例子都比較簡(jiǎn)單,希望給初學(xué)的小伙伴一些參考。后記文章可能比較簡(jiǎn)單,只是分享了幾個(gè)小例子,沒(méi)有對(duì)的用法進(jìn)行詳細(xì)說(shuō)明,大家可以看官方文檔。參考資料中文文檔五個(gè)小案例帶你學(xué)習(xí)火熱的 前言 最近在學(xué)習(xí)vue.js,學(xué)著寫(xiě)了幾個(gè)小例子,自己記錄一下,例子都比較簡(jiǎn)單,希望給初學(xué)vue.js的小伙伴一些參考。 雙向數(shù)據(jù)綁定 點(diǎn)擊查看 數(shù)據(jù)綁定是vue...

    array_huang 評(píng)論0 收藏0
  • node+微信程序實(shí)現(xiàn)商城案例

    說(shuō)明:1、本人也是初次完整使用小程序,如有BUG或者不足的地方請(qǐng)?jiān)贗ssues或者本文下方留言,作者會(huì)盡快修改,謝謝!2、本項(xiàng)目適合初學(xué)者或者準(zhǔn)備自學(xué)小程序的伙伴 小程序功能: |-- images // 公共圖片 |-- lib // 公共文件 |-- pages // 頁(yè)面 ...

    BDEEFE 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<