美文网首页
作业,组件:添加删除,购物车

作业,组件:添加删除,购物车

作者: 滚动的小熊 | 来源:发表于2018-09-21 18:59 被阅读0次

添加删除

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="vue.js"></script>
</head>
<body>
    <div id="app">
        <my-add></my-add>
    </div>
    <script>
        Vue.component('my-add',{
            template:`
            <div>
                <input v-model="arrt"> <button @click="add">添加</button>
                <my-li v-bind:arrName="arr"></my-li>
            </div>
            `,
            data:function(){
                return{
                    arr:["kar98k","M4A1","AMK"],
                    arrt:''
                }
            },
            methods:{
                add:function(){
                    this.arr.push(this.arrt)
                    this.arrt=""
                }
            }
        })
        Vue.component('my-li',{
            props:['arrName'],
            template:`
                <ul>
                    <li v-for="(val,index) in arrName">{{val}} <button @click="btn(index)">删除</button> </li>
                </ul>
            `,
            methods:{
                btn:function(index){
                    this.arrName.splice(index ,1)
                }
            }
        })
        new Vue({
            el:"#app"
        })
    </script>
</body>
</html>

购物车

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <link rel="stylesheet" href="css/bootstrap.css">
</head>
<body>
   <div id='app'>
       <my-father></my-father>
   </div>
    <script src='js/vue.js'></script>
    <script>
        Vue.component('my-father',{
            template:`
              <div class='container'>
               <table class='table table-bordered text-center'>
                  <thead>
                      <tr>
                         <th class='text-center'>编号</th>
                         <th class='text-center'>名称</th>
                         <th class='text-center'>单价</th>
                         <th class='text-center'>数量</th>
                         <th class='text-center'>小计</th>
                       </tr>
                  </thead>
                   <my-child v-bind:product='goods'></my-child>
               </table>
             </div>
            `,
            data:function(){
                return{
                    goods:[
                        {pname:'apple',price:3,count:3,sub:9},
                        {pname:'pear',price:4,count:4,sub:16},
                        {pname:'orange',price:5,count:5,sub:25}
                    ]
                }
            }
        })
       
        Vue.component('my-child',{
            props:['product'],
            template:`
                <tbody>
                  <tr v-for="(value,index) in product">
                     <td>{{index+1}}</td>
                     <td>{{value.pname}}</td>
                     <td>{{value.price}}</td>
                     <td>
                          <button @click='add(index)'>+</button>
                          <span>{{value.count}}</span>
                         <button @click='redu(index)'>-</button> 
                      </td>
                     <td>{{value.sub}}</td>
                  </tr>
                  <tr>
                      <td colspan=5>总价:{{sum}}</td>
                  </tr>
                </tbody>
            `,
            data:function(){
                return{
                    sum:0
                }
            },
            methods:{
                add:function(ind){
                    this.product[ind].count++;
                    //小计、
                    this.product[ind].sub=this.product[ind].count*this.product[ind].price;
                    this.countSum();
                     
                },
                redu:function(ind){
                    if(this.product[ind].count>1){
                       this.product[ind].count--;
                    }
                    //小计
                      this.product[ind].sub=this.product[ind].count*this.product[ind].price;
                     this.countSum();
                },
                countSum:function(){
                    for(var i=0,total=0;i<this.product.length;i++){
                        total+=this.product[i].sub;
                    }
                    this.sum=total;
                }
                
                
            }
        })
        
        
        new Vue({
            el:'#app'
        })
    </script>
</body>
</html>

相关文章

网友评论

      本文标题:作业,组件:添加删除,购物车

      本文链接:https://www.haomeiwen.com/subject/fbhwnftx.html