JavaWeb-仿小米商场(6)商品添加到购物车

JavaWeb-仿小米商场(6):商品添加到购物车

1 功能描述

接上篇 JavaWeb - 仿小米商城(5):商品详情展示 本篇博客将分析和实现小米商城商品添加到购物车 和展示。如以下H5页面所示:

在这里插入图片描述

2 功能分析

2.1 功能逻辑抽象

商品购物车功能在逻辑上并不复杂:在商品界面每当点击商品 <img>标签或商品名称时,都会向后端提 交一个 GET 请求来将本商品数据内容添加到Session。后端在收到请求后查询数据库并以Map形式储存 内容到session。

商品购物车是面向数据库中的 tb_cart表,在购物车列表页面点击结算将数据添加到数据表。在开发时基 于三层架构体系建立对应的 CartServlet 类、CartService 接口和实现类、CartDao 接口和实现类。

备注:vo,dto,domain,entity,pojo的含义

POJO(Plain Ordinary Java Object)简单的Java对象,实际就是普通JavaBeans(规范),pojo是业 务称呼.

entity:实体类,一个类,属性严格对应一个表格的行数据

domain:封装数据库的javabean对象,一个对象可以封装多个表格数据.(domain的范围大于 entity)

DTO:专门负责接收前端表格数据的对应结构的javabean.

vo:view object,视图对象,ajax要什么,就封装什么

POJO与JavaBean的比较:

pojo:用于数据的临时传递,它只能装载数据,作为数据存储的载体,不具有业务逻辑的处理能 力。 javaBean:与pojo相比,它里面可以有其他方法。 JavaBean是可重用组件,需要符合以下条 件:

这个类必须有一个公共的缺省构造函数 这个类的属性使用getter和setter来访问设置数据,其他方 法遵从标准命名规范 这个类可以序列化 3 代码实现

3 代码实现

在这里插入图片描述

3.1 前端

3.1.1 修改商品详情a链接地址

在这里插入图片描述

3.1.2 编写cart.html代码

前端在加载html内容时便向后端提交异步请求。在购物车详情页查询CartServlet里的showCart方法数 据,发出请求向CartServlet获取session中添加的购物项的json数据

cart.html 的js代码如下


        //加一
        function pNum(pid, p, no) {
            var nums = $("#num_count" + no).val();
            if (Number(nums) >= 5) {
                alert("每人限购五件")
            } else {
                nums=parseInt(nums)+1;//购买数量不能超过总库存或者限制购买数量
            }
            $.ajax({
                url: "cart.do?action=updateCartNum&pid=" + pid + "&num=" + nums + "&price=" + p,
                method: "get",
                success: function () {
                    location.href = "cart.html";
                },
                error: function () {
                    alert("服务器异常");
                }
            })
        }

        //减一
        function mNum(pid, p, no) {

            var nums = $("#num_count" + no).val();
            nums=parseInt(nums)-1
            if (Number(nums) < 1) {
                if (confirm("确认要删除吗?")) {
                    nums = 1;
                    alert("最少不能少于一件")
                }
            }
            $.ajax({
                url: "cart.do?action=updateCartNum&pid=" + pid + "&num=" + nums + "&price=" + p,
                method: "get",
                success: function () {
                    location.href = "cart.html";
                },
                error: function () {
                    alert("服务器异常");
                }
            })
        }

        function deleteCartItem(pid) {
            if (confirm("确认要删除吗")) {
                location.href = "cart.do?action=updateCartNum&pid=" + pid + "&num=0";
            }
        }
        function clearCart(pid) {
            if (confirm("确认要删除吗")) {
                location.href = "cart.do?action=clearCart&pid=" + pid;
            }
        }


        $(document).ready(function () {

            //获取session数据显示到页面
            $.get("cart.do?action=showCart", "", function (result) {
                if (result.flag === true) {//登录
                    var sum = 0;//计算总金额变量
                    var index = 1;
                    for (var i in result.data) {
                        var money = result.data[i].quantity * result.data[i].price;
                        var temp = ' <tr> ' +
                            '                        <th>' + index + '</th> ' +
                            '                        <th>' + result.data[i].goodName + '</th> ' +
                            '                        <th>' + result.data[i].price + '</th> ' +
                            '                        <th width="100px"> ' +
                            '                            <div class="input-group"> ' +
                            '         <span class="input-group-btn"> ' +
                            '          <button class="btn btn-default" type="button" ' +
                            '                                            οnclick="mNum(' + result.data[i].goodsId + ',' + result.data[i].price + ',' + index + ')">-</button> ' +
                            '         </span> ' +
                            '                                <input type="text" class="form-control" id="num_count' + index + '" value="' + result.data[i].quantity + '" ' +
                            '                                       readonly="readonly" style="width:40px"> ' +
                            '                                <span class="input-group-btn"> ' +
                            '          <button class="btn btn-default" type="button" ' +
                            '                                            οnclick="pNum(' + result.data[i].goodsId + ',' + result.data[i].price + ',' + index + ')">+</button> ' +
                            '         </span> ' +
                            '                            </div> ' +
                            '                        </th> ' +
                            '                        <th>¥&nbsp;&nbsp' + result.data[i].subtotal + '</th> ' +
                            '                        <th> ' +
                            '                            <button type="button" class="btn btn-default" οnclick="deleteCartItem(' + result.data[i].goodsId + ')">删除</button> ' +
                            '                        </th> ' +
                            '                    </tr>';
                        index++;
                        sum += result.data[i].subtotal;
                        $("#cartBody").append(temp)
                    }
                    $("#total").html("<b>¥&nbsp&nbsp:&nbsp" + sum + "</b>")
                }
            });


        });

3.2 后端

3.2 后端

在 CartServlet 类中定义查询所有商品分类内容的主体逻辑


@WebServlet("/cart.do")
public class CartServlet extends BaseServlet {
    private ResultData resultData = new ResultData();

    //添加商品到购物车
    public String addCart(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        //接收get传递过来的参数,
        String goodsId = req.getParameter("goodsId");
        String goodsname = req.getParameter("goodsname");
        String price = req.getParameter("price");
        Map<String, CartItem> cartItemMap = null;
        //先从session中取出
        cartItemMap = (Map<String, CartItem>) req.getSession().getAttribute(Constants.CART);
        if (cartItemMap == null) {
            cartItemMap = new HashMap<>();
        }

        //之前是有该商品
        if (cartItemMap.containsKey(goodsId)) {
            CartItem cartItem = cartItemMap.get(goodsId);
            //原有数据加1
            cartItem.setQuantity(cartItem.getQuantity() + 1);
            Double total = cartItem.getQuantity() * cartItem.getPrice();
            cartItem.setSubtotal(total);
        } else {         //没有相同商品
            Double v = Double.parseDouble(price);
            CartItem newItem = new CartItem(goodsname, v, goodsId, 1, v);
            cartItemMap.put(goodsId, newItem);
        }
        System.err.println(cartItemMap);
        System.err.println(cartItemMap.get("1"));
        req.getSession().setAttribute(Constants.CART, cartItemMap);
        return Constants.REDIRECT + "/cartSuccess.html";
    }

    //显示商品购物车数到html页面
    public String showCart(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        //接收get传递过来的参数,
        Map<String, CartItem> cartItemMap = (Map<String, CartItem>) req.getSession().getAttribute(Constants.CART);
        if (cartItemMap != null) {
            resultData.setFlag(true);
            resultData.setData(cartItemMap);
        } else {
            resultData.setFlag(false);
            resultData.setErrorMsg("购物车没有数据");
        }
        String json = JSON.toJSONString(resultData);
        System.out.println(json);
        resp.setContentType("application/json;charset=utf-8");
        return json;

    }

    //修改购物车商品数量
    public String updateCartNum(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        //接收get传递过来的参数,
        String goodsId = req.getParameter("pid");
        String numStr = req.getParameter("num");
        Map<String, CartItem> cartItemMap = null;
        //先从session中取出
        cartItemMap = (Map<String, CartItem>) req.getSession().getAttribute(Constants.CART);
        if (cartItemMap != null) {
            //之前是有该商品
            if (cartItemMap.containsKey(goodsId)) {
                CartItem cartItem = cartItemMap.get(goodsId);
                //原有数据加1
                int num = Integer.parseInt(numStr);
                if (num==0){
                    cartItemMap.remove(goodsId);
                }else{
                cartItem.setQuantity(num);
                Double total = cartItem.getQuantity() * cartItem.getPrice();
                cartItem.setSubtotal(total);
                resultData.setFlag(true);
                }
            } else {
                resultData.setFlag(false);
            }

        } else {
            resultData.setFlag(false);
        }
        return null;
    }

    //清除购物车数据
    public String clearCart(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        //情况session
        req.getSession().removeAttribute(Constants.CART);
        return Constants.REDIRECT + "/index.html";

    }


}

后端程序执行顺利的话,返回的响应结果可以使用 chrome浏览器的自动 json 解析功能观察到以下效 果。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-22KOXaFd-1652699011549)(D:\鲲鹏培训\项目\仿小米商城\项目编写过程截图\购物车json数据展示.png)]

{
//情况session
req.getSession().removeAttribute(Constants.CART);
return Constants.REDIRECT + “/index.html”;

}

}


后端程序执行顺利的话,返回的响应结果可以使用 chrome浏览器的自动 json 解析功能观察到以下效 果。

![在这里插入图片描述](https://img-blog.csdnimg.cn/54556e492c2b40a58721d79214fea82e.png#pic_center)


  • 0
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
基于引用[1]和引用提供的信息,可以介绍一下javaweb仿小米商城的实现方式。 1. 技术栈:该系统使用了Java作为后端开发语言,使用了Spring Boot框架进行快速开发,前后端分离采用了Vue.js作为前端发框架,数据库使用了MySQL,项目管理具使用了Maven,缓存使用了Redis。 2. 后端开发:后端采用了Spring Boot框架,使用了SSM(SpringMVC + Spring + MyBatis)作为持久层框架,通过Maven进行项目管理。后端主要负责处理前端请求,与数据库进行交互,实现商品管理、用户管理、订单管理等功能。 3. 前端开发:前端采用了Vue.js作为开发框架,通过Ajax与后端进行数据交互。前端主要负责展示商品信息、用户登录注册、购物管理、订单生成等功能。 4. 数据库设计:使用MySQL作为数据库,设计商品表、用户表、订单表等相关表结构,通过MyBatis进行数据库操作。 5. 缓存管理:使用Redis作为缓存,提高系统性能和响应速度,常用的缓存数据包括商品信息、用户信息等。 6. 安全性:在用户登录注册、订单生成等关键操作中,采用了加密算法和安全验证机制,保证用户数据的安全性。 7. 部署和运维:使用Maven进行项目管理,通过Docker容器化部署,使用Nginx进行反向代理和负载均衡,保证系统的稳定性和可扩展性。 8. 其他功能:系统还可以实现商品搜索、商品推荐、购物管理、订单支付等功能,提升用户体验。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值