当前位置 主页 > 网站技术 > 代码类 >

    vue实现购物车选择功能

    栏目:代码类 时间:2020-01-10 21:09

    使用vue制作一个购物车功能,只是一个测试版本,注重的是功能实现,界面并没有做好,数据也是模拟数据等

    不说那么多,直接上代码

    <template>
     <div >
     
     全选<input type="checkbox" v-model="checkall" @change="check_all()">
     <div v-for="(item,index) in mylist" :key="index">
      <span>{{item.oname}}</span><input type="checkbox" v-model="item.this_all" @change="check_list(index)">
      <p v-for="(goods,nindex) in item.newlist" :key="nindex">
      <input type="checkbox" v-model="goods.check_one" @change="click_input(index,nindex)">{{goods.newname}}--{{goods.price}}元
      </p>
      
     </div>
     <p>总价:{{allprice}}</p>
     <button @click="btn()">提交订单</button>
     
     </div>
    </template>
     
    <script>
    export default {
     name: 'App',
     data(){
      return{
       mylist:[
        {oname:"第一个",this_all:true,newlist:[{newname:"篮球",check_one:true,price:600},{newname:"足球",check_one:true,price:200},{newname:"滑雪",check_one:true,price:150}]},
        {oname:"第二个",this_all:true,newlist:[{newname:"西瓜",check_one:true,price:35},{newname:"桃子",check_one:true,price:20}]},
        {oname:"第三个",this_all:true,newlist:[{newname:"英雄联盟",check_one:true,price:200}]},
     
       ],
       checkall:true,
       allprice:0,
       cpmylist:[]
      }
     },
     mounted:function(){
      this.money();
     },
     
     methods: {
     money:function(){
     var that = this;
     this.allprice=0;
     that.mylist.forEach(item1 =>{
      item1.newlist.forEach(item2 =>{
      if(item2.check_one==true){
       that.allprice+=item2.price;
      }
      })
     })
     
     },
     check_all:function(){
     var that = this;
     that.mylist.forEach(item1 => {
      item1.this_all=that.checkall
      item1.newlist.forEach(item2 => {
      item2.check_one=that.checkall
      })
     });
     that.money();
     },
     
     abc:function(){
     var that = this;
      var aaa = that.mylist.filter(item2 =>{
      return item2.this_all==true
     })
     aaa.length==that.mylist.length ? that.checkall = true : that.checkall = false
     that.money();
     },
     
     check_list:function(i){
     var that = this;
     that.mylist[i].newlist.forEach(item1 =>{
      item1.check_one=that.mylist[i].this_all
     })
     that.abc();
     
     },
     
     click_input:function(i,j){
     var that = this;
     var checklist = that.mylist[i].newlist.filter(item1 =>{
      return item1.check_one==true
     })
     
     checklist.length==that.mylist[i].newlist.length ? that.mylist[i].this_all = true : that.mylist[i].this_all = false
     that.abc();
     
     },
     
     btn:function(){
     var that = this; 
     
     
     that.cpmylist=JSON.parse(JSON.stringify(that.mylist));
     that.cpmylist.filter(item1 =>{
      item1.newlist = item1.newlist.filter(item2 =>{
      return item2.check_one==true
      })
     })
     that.cpmylist=that.cpmylist.filter(item3 =>{
      return item3.newlist.length!=0
     })
     
     if(that.cpmylist.length==0){
      alert("请选择商品哦!")
     }else{
     
      console.log("★★★您购买的商品是:");
      that.cpmylist.forEach(item4 =>{
      console.log("----------"+item4.oname+"店铺----------");
      item4.newlist.forEach(item5 =>{
       console.log("——>:"+item5.newname);
      })
      })
     }
     }
     },
     
    }
    </script>
     
    <style>
    #app {
     font-family: 'Avenir', Helvetica, Arial, sans-serif;
     -webkit-font-smoothing: antialiased;
     -moz-osx-font-smoothing: grayscale;
     text-align: center;
     color: #2c3e50;
     margin-top: 60px;
    }
    </style>