购物车案例【简单版】(三)

简介: 为了巩固MVC的开发模式,下面就写一个购物车的小案例..

购物车的页面

  • 初步把购物项的信息显示出来

<%@ page contentType="text/html;charset=UTF-8" language="java" %>

   <%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>

   <html>

   <head>

       <title>购物车显示页面</title>

   </head>

   <body>

   <h1>购物车显示页面</h1>

   

   <%--empty函数是判断集合中有没有元素--%>

   <%--如果购物车是没有任何购物项的--%>

   <c:iftest="${empty(cart.bookMap)}">

       <h1>您还没有购买过任何的书籍呀!</h1>

   </c:if>

   

   <%--如果购物车有购物项,就应该把购物项的信息显示给用户--%>

   <c:iftest="${!empty(cart.bookMap)}">

   

       <tableborder="1px">

           <tr>

               <td>书籍编号</td>

               <td>名称</td>

               <td>数量</td>

               <td>小计</td>

               <td>操作</td>

           </tr>

           <c:forEachitems="${cart.bookMap}"var="me">

               <tr>

                   <td>${me.key}</td>

                   <td>${me.value.book.name}</td>

                   <td>${me.value.quantity}</td>

                   <td>${me.value.price}</td>

                   <td><ahref="#">删除</a></td>

               </tr>

           </c:forEach>

           <tr>

               <tdcolspan="2"><ahref="#">清空购物车</a></td>

   

               <tdcolspan="2">合计:</td>

               <td>${cart.price}</td>

           </tr>

   

       </table>

   

   </c:if>

   

   

   </table>

   

   </body>

   </html>

  • 效果是这样子的:

image.gif


删除购物车商品

7.jpg

想要删除购物车中的商品,也很简单,把删除操作挂在超链接上,超链接指向DeleteCartServlet,并将想要删除的书本的id带过去(不将id带过去,服务器哪知道你要删除的是哪个)

<td><ahref="${pageContext.request.contextPath}/DeleteCartBook?bookid=${me.key}">删除</a></td>

开发DeleteCartBook的Servlet

//获取得到用户想要删除哪个书本的id

       Stringid=request.getParameter("bookid");


       //获取该用户相对应的购物车对象

       Cartcart=(Cart)request.getSession().getAttribute("cart");


       try{

           //删除购物车的商品,也应该是在BusinessService中有的功能,于是乎又回到BusinessService中写代码

           BusinessServicebusinessService=newBusinessService();

           businessService.deleteBook(id,cart);


           //删除购物车的商品后,也应该直接跳转回去购物车的显示页面中

           request.getRequestDispatcher("/WEB-INF/listCart.jsp").forward(request,response);



       }catch(CartNotFoundExceptione){

           request.setAttribute("message","购物车空了!");

           request.getRequestDispatcher("/message.jsp").forward(request,response);


       }catch(Exceptione){

           e.printStackTrace();

           request.setAttribute("message","删除中出现了异常~待会再试试呗!");

           request.getRequestDispatcher("/message.jsp").forward(request,response);

       }



目录
相关文章
|
JavaScript 前端开发 Java
55dwr - 购物车案例(实现购物车)
55dwr - 购物车案例(实现购物车)
47 0
|
5月前
|
缓存 监控 算法
京东购物车如何提升30%性能
【8月更文挑战第27天】以下是一些提升京东购物车性能的方法:1. 减少网络请求次数,采用异步请求;2. 使用本地和服务器端缓存;3. 优化购物车算法,如商品归堆和实时计算;4. 前端优化,如图片压缩和延迟加载;5. 后端架构优化,包括数据库和服务器资源优化;6. 建立性能监控系统并持续优化。这些措施可显著提升用户体验。
113 0
|
8月前
|
搜索推荐 测试技术
对淘宝购物车进行测试用例设计
对淘宝购物车进行测试用例设计
348 0
|
8月前
|
JavaScript
基础购物车
基础购物车
43 1
|
8月前
|
JavaScript
基础购物车功能
基础购物车功能
uniapp——添加购物车数据以及删除购物车数据
添加购物车数据以及删除购物车数据
253 0
|
前端开发
购物车项目(前端)
购物车项目(前端)
购物车项目(前端)
html+css实战183-购物车
html+css实战183-购物车
149 0
html+css实战183-购物车
|
存储 缓存 NoSQL
【浅谈电商】简易购物车模块(一)
近期接到开发任务,需要以图书为中心开发一套书籍在线商城系统,由于之前没有做过相关的系统,借此机会梳理总结一下各个模块的处理逻辑。 简易实现,项目开发中,有更好的想法请指教。
363 0