二、Vue实现购物车功能

 根据表单的双向绑定,实现购物车的基本功能:

计算总价

商品增加

商品删除

全选

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
    <style>
       
    </style>
</head>
<body>
    <div id="app">
        <!--1. 全选按钮:当选择该按钮时,选中全部商品,否则全不选
            可通过布尔变量checkAll来控制

            @change="allChange": 当该按钮变化时,触发事件allChange

            注意:当有商品取消选中时,则取消全选
        -->
        全选:<input type="checkbox" @change="allChange" v-model="checkAll" />

        <!--2. 商品列表
            注意:当某个商品没有选中时,则全选按钮为未选中状态
            因此为每个选项添加事件 @change="liChange"
        -->
        <ul>
            <li v-for="data in datalist">
                <input type="checkbox" @change="liChange" v-model="group" :value="data"/>
                {{data}}

                <!--3. 为每个商品添加:减小 当前数目 增加
                    增加:可直接通过data.number++实现
                    减小:由于可能出现负值,需要调用方法subClick实现
                -->
                <button @click="subClick(data)">sub</button>
                {{data.number}}
                <button @click="data.number++">add</button>
            </li>
        </ul>
       {{group}}

       <p>商品总金额:{{getSum()}}</p>
    </div>
    
   

    <script>
        var v = new Vue({
            el: "#app",
            data:{
                checkAll:false,
                group:[],
               datalist:[
                   {
                       name:"商品1",
                       price:10,
                       number:1,
                       id:"1",
                   },
                   {
                       name:"商品2",
                       price:20,
                       number:2,
                       id:"3",
                   },
                   {
                       name:"商品3",
                       price:30,
                       number:3,
                       id:"3",
                   }
               ]
            },
            methods:{
                /*
                1.获取选中商品的总金额
                  遍历选中的商品数组group,计算总金额,并返回
                */
                getSum(){
                    var sum=0;
                    for(var i in this.group){
                        sum+=this.group[i].price*this.group[i].number
                    }
                    return sum
                },
                /*
                2.当全选按钮发生变化时
                */
                allChange(){
                    if(this.checkAll){//全选,则选中所有商品
                        this.group=this.datalist 
                    }else{//全不选
                        this.group=[]
                    }
                },

                /*
                 3. 当商品的复选按钮发生变化时

                 需调整全选按钮:
                 商品全部选中时,checkAll=true
                 否则,checkAll=false
                 只需判断选中商品数组的长度和所有商品数组的长度是否相等
                */
                liChange(){
                    if(this.group.length===this.datalist.length){//全选按钮为选中状态
                        this.checkAll=true
                    }else{//全选按钮为未选中状态
                        this.checkAll=false
                    }
                },

                /*
                4.对商品数量进行减操作
                  商品数量不能为负值
                */
                subClick(data){
                    data.number--;
                    if(data.number<0){
                        data.number=0;
                    }
                }
            }
               
        })
    </script>
</body>
</html>

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实现购物车功能需要结合Spring Boot和Vue框架,以下是一种可能的实现方案。 首先,在Spring Boot中创建商品和购物车相关的数据模型和数据库表结构。可以创建商品表、购物车表,以及中间表来建立商品和购物车之间的关系。通过JPA或者MyBatis等框架与数据库进行交互,实现增删改查等基本的数据操作。 接下来,使用Spring Boot创建商品和购物车相关的接口。可以创建商品的添加、删除、修改等接口,以及购物车的商品添加、删除、修改接口。在接口中,可以处理一些逻辑,比如商品添加到购物车时可以判断购物车是否已存在该商品,如果存在则数量增加,不存在则添加新的购物车项。 在Vue中,创建商品列表和购物车页面。可以使用axios等工具从后端获取商品列表,并展示给用户。用户在页面上可以点击“加入购物车”按钮,将选中的商品添加到购物车中。在购物车页面,展示当前用户已添加的购物车商品列表,并实现数量增减和删除的功能。每次数量改变或删除操作时,通过接口与后端进行数据交互,更新购物车中的商品信息。 在Vue中,还需要实现购物车商品总价的计算和结算功能。可以通过遍历购物车商品列表,计算每个商品的小计,再将所有小计相加得到总价。用户点击结算按钮时,可以将购物车商品列表传递给后端进行支付操作。 以上是基本的购物车功能实现方案。当然,具体实现过程中可能还会涉及到其他细节问题,比如商品详情展示、用户登录、权限控制等,需要根据实际需求进一步完善和实现
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值