前端用js如何实现购物车功能,如图那样的效果

前端用js如何实现购物车功能,如图那样的效果,第1张

这是需要多个方法才能完成的

1,需要动态添加商品那一条显示的function

2,个数那个需要一个增加减少的function

3, 需要个统计总数量的

4,需要一个检测checkbox的

你做到什么程度了

初步怀疑你的删除事件绑定有问题:新加入的DOM元素未绑定到事件。这种情况应该使用事件委派来做,你用 jQuery 吗?假设你的购物车列表的 HTML 结构如下:

<ul id="cartList">

    <li>

        购物车商品1

        <button>删除</button>

    </li>

    <li>

        购物车商品2

        <button>删除</button>

    </li>

    ……

</ul>

则删除购物车商品的代码为(用了 jQuery):

$('#cartList').on('click', 'button', function() {  // 委派 button 的点击事件

    $(this).parent().remove()  // 移除购物车里当前商品

})

购物车管理模块主要功能有如下几个部分:(1)创建购物车 当客户登录后,系统会给客户创建一个购物车放入服务器的Session会话中。使客户在整个会话中都拥有一个相同的购物车。这里主要运用了Http协议中的会话机制,将购物车保存在客户的会话中,这样在整个客户游览不同页面商品的过程中,都会使用同一个购物车对象。 具体执行步骤:(1)从客户的请求对象中获取Session会话对象(2)从会话对象中获取购物车对象(3)判断是购物车对象是不是空的,如果是空是就创建一个/* * 在监听到session被创建之后,就立即向session中添加一个购物车Car; */public void sessionCreated(HttpSessionEvent arg0) { HttpSession session = arg0.getSession() Cart cart=new Cart() session.setAttribute("cart", cart) }/** 从session中获得购物车*/ Cart cart = (Cart) session.getAttribute("cart") if (cart == null) { cart = new Cart() }(2)向购物车中添加一个商品项 客户在查看网页上的一个商品时,当向服务器发送一个“添加到购物车”的请求时,会执行这个功能。功能执行过程:(1)从客户请求对象中获取商品的ID(2)调用业务层的方法根据商品ID去数据查询商品的信息,返回商品对象(3)从商品对象中获取商品名,商品价格,来构建一个商品项对象(4)从Session会话中获取购物车对象(5)调用业务层的方法来根据购物车对象和商品项对象来执行添加 *** 作(6)将些商品项对象放入到购物车中 部分实现代码: /** 从数据库中把商品取到;*/ ProductService productService = (ProductService) ServiceFactory.getInstance().getService(Globals.PRODUCT_SERVICE) Integer id = Integer.parseInt(request.getParameter("productid")) Product product = productService.getProductById(id) /** 在向购物车中添加商品的时候会判断商品是否已经存在,* 已存在的就不让在加入了;*/ if (cart.isExist(id)) { message = "该商品已经存在!请<a onclick='javascript:history.go(-1)'>返回</a>!" request.setAttribute("message", message) return mapping.findForward("error") } else { /** 向购物车添加一个商品;*/ cart.addCart(product) session.setAttribute("cart", cart) return mapping.findForward("addcartsuccess") }


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/bake/11904437.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-19
下一篇 2023-05-19

发表评论

登录后才能评论

评论列表(0条)

保存