vue实现简单的移动端购物车案例

通过vue实现一个简单的移动端购物车案例,包括显示商品基本信息,添加商品数量,选择及全选商品,进行计算价钱、购买或删除等操作。效果及演示如下图

 实现步骤

一、首先将需要用到的vue.js文件准备,或直接使用cdn地址

<script src="https://cdn.jsdelivr.net/npm/[email protected]/dist/vue.js"></script>

二、然后对页面整体进行布局和样式完善,主要包括头部、列表项和尾部确认提交

<body>
        <div id="app">
            <p>购物车</p>
            <p>共{{shoppingList.length}}件宝贝</p>
            <div class="shoppingMain">
                <div class="shoppingItem" v-for="(item,index) in shoppingList"><!--列表项-->
                    <div class="selectCircle" :class="{checked:item.isSelect}" @click="selectGoods(item)"></div>
                    <div class="shoppingImg">
                        <img :src="item.imgurl" alt="">
                    </div>
                    <div class="itemRight">
                        <p class="title">{{item.title}}</p>
                        <p>{{item.color}}</p>
                        <div class="numAndMoney">
                            <p>¥{{item.money}}</p>
                            <div class="numberControl">
                                <a class="btn" @click="numDel(item,index)">-</a>
                                <input type="text" v-model="item.num" readonly="readonly">
                                <a class="btn" @click="numAdd(item,index)">+</a>
                            </div>
                        </div>
                    </div>
                </div>
            </div>
            <div class="bottomMain">                <!--底部固定栏-->
                <div class="selectCircle" :class="{checked:allSelect}" @click="allGoodsSelect"></div>
                <span style="padding: 10px">全选</span>
                <button class="bottombtn2" @click="delGoods">删除</button>  
                <button class="bottombtn1" @click="buyGoods">¥{{sum}}&nbsp;结算</button>                
            </div>
        </div>
    </body>
   /* 样式设置 */
            body{
                margin: 0;
                padding: 0;
                background: #e0dada;
            }
            button{
                outline: none;
                border-color: transparent;
                box-shadow:none;
            }
            #app{
                margin: 0;
                padding: 0;
                width: 100%;
               
            }
            .shoppingMain{
                width: 100%;
                height: auto;
                margin-bottom: 70px;
            }
            .shoppingItem{
                width: 96%;
                margin-left: 2%;
                margin-bottom: 10px;
                background: #fff;
                border-radius:5px;
                display: flex;
            }
            .selectCircle{
                width: 15px;
                height: 15px;
                border: 1px solid #a7a5a5;
                border-radius: 50%;
                margin: auto 0px auto 10px;
            }
            .shoppingImg{
                width: 100px;
                height: 100px;
                padding: 10px;
            }
            .shoppingImg img{
                height: 100%;
                width: 100%;
            }
            .itemRight{
                font-size: 10px;
                width: 200px;
            }
            .title{
                display: -webkit-box;
                -webkit-line-clamp: 2;
                -webkit-box-orient: vertical;
                overflow: hidden;
            }
            .numAndMoney{
                display: flex;
            }
            input{
                width: 40px;
                height: 20px;
                margin: 10px;
                text-align: center;
            }
            .numberControl{
                position: absolute;
                right: 30px;
            }
            .bottomMain{
                position: fixed;
                width: 100%;
                height: auto;
                border: 1px #a7a5a5 solid;
                bottom: 0;
                left: 0;
                background: #fff;
                display: flex;
                padding: 10px;
            }
            .bottombtn1{
                width:auto;
                height: 30px;
                border: none;
                color: #fff;
                background-color: #e26411;
                border-radius: 25px;
                margin: 5px 0 0 20px;
            }
            .bottombtn2{
                width:70px;
                height: 30px;
                border: none;
                color: #fff;
                background-color: #cecac7;
                border-radius: 25px;
                margin: 5px 0 0 80px;
            }
            .checked{
                background: #e26411;
                border: 1px solid rgba(0, 0, 0, 0)
            }

三、对数据进行模拟和操作

<script>      
            var vm = new Vue({                //实例化Vue
                el:'#app',
                data:{                        //数据
                    shoppingList:[
                        {
                            imgurl:"img/item.jpg",
                            title:"女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包",
                            color:"粉色",
                            money:149,
                            num:"1",
                            isSelect:false,
                        },
                        {
                            imgurl:"img/item.jpg",
                            title:"女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包",
                            color:"粉色",
                            money:149,
                            num:"1",
                            isSelect:false,
                        },
                        {
                            imgurl:"img/item.jpg",
                            title:"女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包",
                            color:"粉色",
                            money:149,
                            num:"1",
                            isSelect:false,
                        },
                        {
                            imgurl:"img/item.jpg",
                            title:"女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包",
                            color:"粉色",
                            money:149,
                            num:"1",
                            isSelect:false,
                        },
                        {
                            imgurl:"img/item.jpg",
                            title:"女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包",
                            color:"粉色",
                            money:149,
                            num:"1",
                            isSelect:false,
                        },
                    ],
                    allSelect:false,
                    sum:0
                },
                methods:{
                    selectGoods(item){        //商品选择方法
                        item.isSelect = !item.isSelect    //改变选择状态
                        this.allSelect = false
                        if(item.isSelect == true){
                            this.sum = this.sum+(item.money*item.num)
                        }else{
                            this.sum = this.sum-(item.money*item.num)
                        }                                //结算处商品总额计算
                    },
                    allGoodsSelect(){                    //全选商品方法
                        this.allSelect = !this.allSelect    //改变选择状态
                        if(this.allSelect == true){
                            this.sum=0
                            for(var i=0;i<this.shoppingList.length;i++){
                                this.shoppingList[i].isSelect = true;
                                this.sum = this.sum+(this.shoppingList[i].money*this.shoppingList[i].num)
                            }
                        }else{
                            for(var i=0;i<this.shoppingList.length;i++){
                                this.sum = this.sum-(this.shoppingList[i].money*this.shoppingList[i].num)
                                this.shoppingList[i].isSelect = false;
                            }
                        }                                    //结算处商品总额计算
                    },
                    numAdd(item,index){                     //商品数量增加
                        item.num++
                        if(item.isSelect == true){
                            this.sum = this.sum+item.money
                        }                                    //已选择商品增加数量,需要增加总额
                    },
                    numDel(item,index){                        //商品数量减少
                        item.num--
                        if(item.isSelect == true){
                            this.sum = this.sum-item.money
                        }                                     //已选择商品减少数量,需要减少总额
                        if(item.num == 0){
                            this.shoppingList.splice(index,1)
                        }                                    //数量减少为0,需要删除对应数据
                    },
                    buyGoods(){                              //购买方法,这里只弹出提示所购买商品总额
                        alert("购买成功,共花费"+this.sum+"元")
                    },
                    delGoods(){                              //删除商品方法
                        this.sum = 0;                        //所选商品被删除,总额置0
                        for(var i=0;i<this.shoppingList.length;i++){
                            if(this.shoppingList[i].isSelect){
                                this.shoppingList.splice(i,1)
                                i--
                            }
                        }                                    //对所选商品进行删除操作
                        if(this.allSelect){
                            this.shoppingList.splice(0,this.shoppingList.length);
                            this.allSelect = false
                        }                                    //全选商品后进行全部删除
                    }
                }
            })
        </script>

完整代码

<html>
    <head>
        <meta http-equiv="Content-Type" content="text/html;charset=UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1,minimum-scale=1.0,maximum-scale=1.0,user-scalable=no">
        <meta http-equiv="X-UA-Compatible" content="IE=edge">
        <title>购物车</title>
        <script src="https://cdn.jsdelivr.net/npm/[email protected]/dist/vue.js"></script>
        <style>
            body{
                margin: 0;
                padding: 0;
                background: #e0dada;
            }
            button{
                outline: none;
                border-color: transparent;
                box-shadow:none;
            }
            #app{
                margin: 0;
                padding: 0;
                width: 100%;
               
            }
            .shoppingMain{
                width: 100%;
                height: auto;
                margin-bottom: 70px;
            }
            .shoppingItem{
                width: 96%;
                margin-left: 2%;
                margin-bottom: 10px;
                background: #fff;
                border-radius:5px;
                display: flex;
            }
            .selectCircle{
                width: 15px;
                height: 15px;
                border: 1px solid #a7a5a5;
                border-radius: 50%;
                margin: auto 0px auto 10px;
            }
            .shoppingImg{
                width: 100px;
                height: 100px;
                padding: 10px;
            }
            .shoppingImg img{
                height: 100%;
                width: 100%;
            }
            .itemRight{
                font-size: 10px;
                width: 200px;
            }
            .title{
                display: -webkit-box;
                -webkit-line-clamp: 2;
                -webkit-box-orient: vertical;
                overflow: hidden;
            }
            .numAndMoney{
                display: flex;
            }
            input{
                width: 40px;
                height: 20px;
                margin: 10px;
                text-align: center;
            }
            .numberControl{
                position: absolute;
                right: 30px;
            }
            .bottomMain{
                position: fixed;
                width: 100%;
                height: auto;
                border: 1px #a7a5a5 solid;
                bottom: 0;
                left: 0;
                background: #fff;
                display: flex;
                padding: 10px;
            }
            .bottombtn1{
                width:auto;
                height: 30px;
                border: none;
                color: #fff;
                background-color: #e26411;
                border-radius: 25px;
                margin: 5px 0 0 20px;
            }
            .bottombtn2{
                width:70px;
                height: 30px;
                border: none;
                color: #fff;
                background-color: #cecac7;
                border-radius: 25px;
                margin: 5px 0 0 80px;
            }
            .checked{
                background: #e26411;
                border: 1px solid rgba(0, 0, 0, 0)
            }
        </style>
    </head>
    <body>
        <div id="app">
            <p>购物车</p>
            <p>共{{shoppingList.length}}件宝贝</p>
            <div class="shoppingMain">
                <div class="shoppingItem" v-for="(item,index) in shoppingList">
                    <div class="selectCircle" :class="{checked:item.isSelect}" @click="selectGoods(item)"></div>
                    <div class="shoppingImg">
                        <img :src="item.imgurl" alt="">
                    </div>
                    <div class="itemRight">
                        <p class="title">{{item.title}}</p>
                        <p>{{item.color}}</p>
                        <div class="numAndMoney">
                            <p>¥{{item.money}}</p>
                            <div class="numberControl">
                                <a class="btn" @click="numDel(item,index)">-</a>
                                <input type="text" v-model="item.num" readonly="readonly">
                                <a class="btn" @click="numAdd(item,index)">+</a>
                            </div>
                        </div>
                    </div>
                </div>
            </div>
            <div class="bottomMain">
                <div class="selectCircle" :class="{checked:allSelect}" @click="allGoodsSelect"></div>
                <span style="padding: 10px">全选</span>
                <button class="bottombtn2" @click="delGoods">删除</button>  
                <button class="bottombtn1" @click="buyGoods">¥{{sum}}&nbsp;结算</button>                
            </div>
        </div>

        <script>      
            var vm = new Vue({
                el:'#app',
                data:{
                    shoppingList:[
                        {
                            imgurl:"img/item.jpg",
                            title:"女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包",
                            color:"粉色",
                            money:149,
                            num:"1",
                            isSelect:false,
                        },
                        {
                            imgurl:"img/item.jpg",
                            title:"女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包",
                            color:"粉色",
                            money:149,
                            num:"1",
                            isSelect:false,
                        },
                        {
                            imgurl:"img/item.jpg",
                            title:"女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包",
                            color:"粉色",
                            money:149,
                            num:"1",
                            isSelect:false,
                        },
                        {
                            imgurl:"img/item.jpg",
                            title:"女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包",
                            color:"粉色",
                            money:149,
                            num:"1",
                            isSelect:false,
                        },
                        {
                            imgurl:"img/item.jpg",
                            title:"女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包女包",
                            color:"粉色",
                            money:149,
                            num:"1",
                            isSelect:false,
                        },
                    ],
                    allSelect:false,
                    sum:0
                },
                methods:{
                    selectGoods(item){
                        item.isSelect = !item.isSelect
                        this.allSelect = false
                        if(item.isSelect == true){
                            this.sum = this.sum+(item.money*item.num)
                        }else{
                            this.sum = this.sum-(item.money*item.num)
                        }
                    },
                    allGoodsSelect(){
                        this.allSelect = !this.allSelect
                        if(this.allSelect == true){
                            this.sum=0
                            for(var i=0;i<this.shoppingList.length;i++){
                                this.shoppingList[i].isSelect = true;
                                this.sum = this.sum+(this.shoppingList[i].money*this.shoppingList[i].num)
                            }
                        }else{
                            for(var i=0;i<this.shoppingList.length;i++){
                                this.sum = this.sum-(this.shoppingList[i].money*this.shoppingList[i].num)
                                this.shoppingList[i].isSelect = false;
                            }
                        }
                    },
                    numAdd(item,index){
                        item.num++
                        if(item.isSelect == true){
                            this.sum = this.sum+item.money
                        }
                    },
                    numDel(item,index){
                        item.num--
                        if(item.isSelect == true){
                            this.sum = this.sum-item.money
                        }
                        if(item.num == 0){
                            this.shoppingList.splice(index,1)
                        }
                    },
                    buyGoods(){
                        alert("购买成功,共花费"+this.sum+"元")
                    },
                    delGoods(){
                        this.sum = 0;
                        for(var i=0;i<this.shoppingList.length;i++){
                            if(this.shoppingList[i].isSelect){
                                this.shoppingList.splice(i,1)
                                i--
                            }
                        }
                        if(this.allSelect){
                            this.shoppingList.splice(0,this.shoppingList.length);
                            this.allSelect = false
                        }
                    }
                }
            })
        </script>
    </body>
</html>

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章