网上图书商城5--购物车模块2
2016-12-04 16:04
375 查看
结算
list.jsp
<a href="javascript:jiesuan();" id="jiesuan" class="jiesuan"></a>
<form id="jieSuanForm" action="<c:url value='/CartItemServlet'/>" method="post"> <input type="hidden" name="cartItemIds" id="cartItemIds"/> <input type="hidden" name="total" id="hiddenTotal"/> <input type="hidden" name="method" value="loadCartItems"/> </form> function jiesuan() { // 1. 获取所有被选择的条目的id,放到数组中 var cartItemIdArray = new Array(); $(":checkbox[name=checkboxBtn][checked=true]").each(function() { cartItemIdArray.push($(this).val());//把复选框的值添加到数组中 }); // 2. 把数组的值toString(),然后赋给表单的cartItemIds这个hidden $("#cartItemIds").val(cartItemIdArray.toString()); // 把总计的值,也保存到表单中 $("#hiddenTotal").val($("#total").text()); // 3. 提交这个表单 $("#jieSuanForm").submit(); }
servlet
public String loadCartItems(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { /* * 1. 获取cartItemIds参数 */ String cartItemIds = req.getParameter("cartItemIds"); double total = Double.parseDouble(req.getParameter("total")); /* * 2. 通过service得到List<CartItem> */ List<CartItem> cartItemList = cartItemService.loadCartItems(cartItemIds); /* * 3. 保存,然后转发到/cart/showitem.jsp */ req.setAttribute("cartItemList", cartItemList); req.setAttribute("total", total); req.setAttribute("cartItemIds", cartItemIds); return "f:/jsps/cart/showitem.jsp"; }
Dao
加载多个CartItem
public List<CartItem> loadCartItems(String cartItemIds) throws SQLException { /* * 1. 把cartItemIds转换成数组 */ Object[] cartItemIdArray = cartItemIds.split(","); /* * 2. 生成wehre子句 */ String whereSql = toWhereSql(cartItemIdArray.length); /* * 3. 生成sql语句 */ String sql = "select * from t_cartitem c, t_book b where c.bid=b.bid and " + whereSql; /* * 4. 执行sql,返回List<CartItem> */ return toCartItemList(qr.query(sql, new MapListHandler(), cartItemIdArray)); }
showitem.jsp
<c:choose> <c:when test="${empty cartItemList }">嘻嘻~</c:when> <c:otherwise> <form id="form1" action="<c:url value='/OrderServlet'/>" method="post"> <input type="hidden" name="cartItemIds" value="${cartItemIds }"/> <input type="hidden" name="method" value="createOrder"/> <table width="95%" align="center" cellpadding="0" cellspacing="0"> <tr bgcolor="#efeae5"> <td width="400px" colspan="5"><span style="font-weight: 900;">生成订单</span></td> </tr> <tr align="center"> <td width="10%"> </td> <td width="50%">图书名称</td> <td>单价</td> <td>数量</td> <td>小计</td> </tr> <c:forEach items="${cartItemList }" var="cartItem"> <tr align="center"> <td align="right"> <a class="linkImage" href="<c:url value='/jsps/book/desc.jsp'/>"><img border="0" width="54" align="top" src="<c:url value='/${cartItem.book.image_b }'/>"/></a> </td> <td align="left"> <a href="<c:url value='/jsps/book/desc.jsp'/>"><span>${cartItem.book.bname }</span></a> </td> <td>¥${cartItem.book.currPrice }</td> <td>${cartItem.quantity }</td> <td> <span class="price_n">¥<span class="subtotal">${cartItem.subtotal }</span></span> </td> </tr> </c:forEach> <tr> <td colspan="6" align="right"> <span>总计:</span><span class="price_t">¥<span id="total">${total }</span></span> </td> </tr> <tr> <td colspan="5" bgcolor="#efeae5"><span style="font-weight: 900">收货地址</span></td> </tr> <tr> <td colspan="6"> <input id="addr" type="text" name="address" value="北京市 昌平区 西三旗 金燕龙办公楼1层 传智播客 张三爷"/> </td> </tr> <tr> <td style="border-top-width: 4px;" colspan="5" align="right"> <a id="linkSubmit" href="javascript:$('#form1').submit();">提交订单</a> </td> </tr> </table> </form> </c:otherwise> </c:choose>
相关文章推荐
- 网上图书商城项目学习笔记-014购物车模块页面javascrip
- 网上图书商城4--购物车模块1
- 网上图书商城项目学习笔记-012BOOK模块查询2
- 网上图书商城6--订单模块1
- web day25 web day24 小项目练习图书商城, 购物车模块,订单模块,支付(易宝支付)
- 网上图书商城8--订单模块3
- 网上图书商城3--Book模块
- 网上图书商城项目学习笔记-025分类管理模块分析及查询所有分类实现
- 网上图书商城7--订单模块2
- 网上图书商城项目学习笔记-031图书管理模块介绍及添加图书
- 图书商城:购物车模块
- 网上图书商城项目学习笔记-013 添加购物车及我的购物车
- 网上图书商城项目学习笔记-015删除和批量删除购物车条目
- javaweb图书商城设计之分类模块(2)
- 网上图书商城项目学习笔记-016修改条目数量
- 网上图书商城项目学习笔记-032编辑图书第一步
- web day26 小项目练习图书商城 后台分类管理模块,图书管理模块,前台登陆过滤
- 图书商城:图书模块
- 网上图书商城项目学习笔记-017结算,跳转结算页面
- 项目之网上商城 购物车 总结 更新中。。。