购物车项目(前端)

简介: 购物车项目(前端)

今天给大家讲的就是session项目,用到了昨天的那篇文章里面的一些东西。

今天就不多说了,可以看下面的思维导图。



下面是这个项目的效果图,用到了一些插件。



以下是代码


index.jsp主页面


<%@page import="com.zking.entity.Goods"%>
<%@page import="java.util.ArrayList"%>
<%@page import="com.zking.dao.GoodsDao"%>
<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
<!-- 引用jQuery库 -->
<script type="text/javascript" src="js/jquery-3.3.1.js"></script>
<script type="text/javascript" src="js/bootstrap.js"></script>
<link rel="stylesheet" type="text/css" href="css/bootstrap.min.css"/>
<script type="text/javascript">
  function gm(bid) {
  //跳转到dogwc页面
  //alert(bid);
  location.href="dogwc.jsp?bid="+bid;
  }
</script>
</head>
<body>
  <table class="table table-hover">
  <tr>
    <td>商品编号</td>
    <td>商品名称</td>
    <td>商品价格</td>
    <td>商品介绍</td>
    <td>商品图片</td>
    <td>
    <span class="glyphicon glyphicon-cog"></span>
    </td>
  </tr>
  <%
    GoodsDao gd = new GoodsDao();
    ArrayList<Goods> glist = gd.getAll();
    for(Goods g:glist){
  %>
  <tr>
    <td><%=g.getBid() %></td>
    <td><%=g.getBname() %></td>
    <td><%=g.getBprice() %></td>
    <td><%=g.getBinfo() %></td>
    <td>
    <img alt="" src="<%=g.getBface() %>"> 
    </td>
    <td>
    <button onclick="gm(<%=g.getBid() %>)" class="btn btn-success">添加购物车</button>
    </td>
  </tr>
  <%} %>
  </table>
</body>
</html>


dogwc.jsp


<%@page import="com.zking.dao.GoodsDao"%>
<%@page import="com.zking.entity.OrderItem"%>
<%@page import="java.util.ArrayList"%>
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<%
//获取商品订单的数量
String number =request.getParameter("gn");
int count=1;
if(number!=null){
  count=Integer.valueOf(number);
}
//接受商品的编号
int bid=Integer.valueOf(request.getParameter("bid"));
//构造小订单对象
OrderItem oi=new OrderItem();
//给属性赋值
oi.setGoods(new GoodsDao().getById(bid));
//订单中的商品数量
oi.setGnumber(1);
//订单总价
oi.setSumPrice();
//获取session中的订单集合
ArrayList<OrderItem> olist=(ArrayList<OrderItem>)session.getAttribute("olist");
if(olist==null){
//创建订单集合
olist=new ArrayList<>();
}
boolean b=true;//表示默认 没有相同的订单
double SumPrice=0;
//遍历订单集合,判断是否已存在相同商品订单
for(int i=0;i<olist.size();i++){
  if(bid==olist.get(i).getGoods().getBid()){
  //number为空说明是从index页面过来的
  if(number==null){
    //修改数量:原来的数量+1
    olist.get(i).setGnumber(olist.get(i).getGnumber()+1);
  //修改总价
  olist.get(i).setSumPrice();
  }else{//number为空说明是从spcar页面过来的
    //修改数量:原来的数量修改为count
    olist.get(i).setGnumber(count);
  //修改总价
  olist.get(i).setSumPrice();
  }
  b=false;
  }
}
if(b){
  //把订单放到ArrayList集合中
olist.add(oi);
}
//把集合放到session中
session.setAttribute("olist", olist);
//遍历订单集合
for(int i=0;i<olist.size();i++){
  SumPrice+=olist.get(i).getSumPrice();
  }
session.setAttribute("SumPrice", SumPrice);
//跳转页面
response.sendRedirect("spcar.jsp");
%>


dodele.jsp删除


<%@page import="com.zking.entity.OrderItem"%>
<%@page import="java.util.ArrayList"%>
<%@ page language="java" contentType="text/html; charset=UTF-8"
  pageEncoding="UTF-8"%>
<%
//接受商品的编号
int bid=Integer.valueOf(request.getParameter("bid"));
//获取session中的订单集合
ArrayList<OrderItem>olist=(ArrayList<OrderItem>)session.getAttribute("olist");
//遍历订单集合,判断是否已存在相同商品订单
for(int i=0;i<olist.size();i++){
  if(bid==olist.get(i).getGoods().getBid()){
  olist.remove(i);
  }
}
double SumPrice=0;
for(int i=0;i<olist.size();i++){
  SumPrice+=olist.get(i).getSumPrice();
  }
session.setAttribute("SumPrice", SumPrice);
//把集合放到session中
session.setAttribute("olist", olist);
//跳转页面
response.sendRedirect("spcar.jsp");
%>


spcar.jsp购物车页面


<%@page import="com.zking.entity.OrderItem"%>
<%@page import="java.util.ArrayList"%>
<%@ page language="java" contentType="text/html; charset=UTF-8"
  pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
<!-- 引用jQuery库 -->
<script type="text/javascript" src="js/jquery-3.3.1.js"></script>
<script type="text/javascript" src="js/bootstrap.js"></script>
<link rel="stylesheet" type="text/css" href="css/bootstrap.min.css" />
<script type="text/javascript">
function xg(obj,bjd) {
  var gnumber=obj.value;
  if(gnumber>0){
  location.href="dogwc.jsp?bid="+bjd+"&gn="+gnumber;
  }else{
  alert("商品数量不能<=0:");
  }
}
function ff(xx,bid,i) {
  var gnumber=document.getElementById(xx).value;
  if(gnumber>0){
  if(i==1){
  gnumber--;
  location.href="dogwc.jsp?bid="+bid+"&gn="+gnumber;
  }else if(i==2) {
  gnumber++;
  location.href="dogwc.jsp?bid="+bid+"&gn="+gnumber;
  }
  }else{
  alert("商品数量不能<=0:");
  }
}
</script>
</head>
<body>
<h1 align="center">
<a href="index.jsp">
<span class="glyphicon glyphicon-home"></span>
</a>
</h1>
<table class="table table-hover">
  <tr>
<td>商品图片</td>
<td>商品名称</td>
<td>商品价格</td>
<td>商品介绍</td>
<td>商品数量</td>
<td>订单总价</td>
<td>操作一下</td>
</tr>
<%
// 获取到session中的订单集合
ArrayList<OrderItem> olist=(ArrayList<OrderItem>)session.getAttribute("olist");
//把订单绑定到页面
for(int i=0;i<olist.size();i++){
%>
  <tr>
  <td>
  <img alt="" src="<%=olist.get(i).getGoods().getBface() %>">
  </td>
<td><%=olist.get(i).getGoods().getBname() %></td>
<td><%=olist.get(i).getGoods().getBprice() %></td>
<td><%=olist.get(i).getGoods().getBinfo() %></td>
<td>
<button onclick="ff(<%=olist.get(i).getGoods().getBid() %>,<%=olist.get(i).getGoods().getBid() %>,1)">-</button>
<input onblur="xg(this,<%=olist.get(i).getGoods().getBid() %>)" id="<%=olist.get(i).getGoods().getBid() %>" style='width: 40px;text-align:center;'type="text" value="<%=olist.get(i).getGnumber() %>">
<button onchange="if(/\D/.test(this.value)){alert('只能输入数字');this.value='';}" onclick="ff(<%=olist.get(i).getGoods().getBid() %>,<%=olist.get(i).getGoods().getBid() %>,2)">+</button>
</td>
<td><%=olist.get(i).getSumPrice() %></td>
<td><a href="dodele.jsp?bid=<%=olist.get(i).getGoods().getBid() %>"><span class="glyphicon glyphicon-trash"></span></a></td>
</tr>
<%} %>
</table>
<p align="right" style="margin-rigth:40px">
<button class="btn btn-success">总价格:<%=session.getAttribute("SumPrice") %></button>
</p>
</body>
</html>
相关文章
|
2月前
|
前端开发 JavaScript 定位技术
一、前端高德地图注册、项目中引入、渲染标记(Marker)and覆盖物(Circle)
文章介绍了如何在前端项目中注册并使用高德地图API,包括注册高德开放平台账号、引入高德地图到项目、以及如何在地图上渲染标记(Marker)和覆盖物(Circle)。
85 1
|
3月前
|
前端开发 Java 编译器
【前端学java】java基础练习缺少项目?看这篇文章就够了!(完结)
【8月更文挑战第11天】java基础练习缺少项目?看这篇文章就够了!(完结)
40 0
|
26天前
|
JavaScript 前端开发 Docker
前端全栈之路Deno篇(二):几行代码打包后接近100M?别慌,带你掌握Deno2.0的安装到项目构建全流程、剖析构建物并了解其好处
在使用 Deno 构建项目时,生成的可执行文件体积较大,通常接近 100 MB,而 Node.js 构建的项目体积则要小得多。这是由于 Deno 包含了完整的 V8 引擎和运行时,使其能够在目标设备上独立运行,无需额外安装依赖。尽管体积较大,但 Deno 提供了更好的安全性和部署便利性。通过裁剪功能、使用压缩工具等方法,可以优化可执行文件的体积。
105 3
前端全栈之路Deno篇(二):几行代码打包后接近100M?别慌,带你掌握Deno2.0的安装到项目构建全流程、剖析构建物并了解其好处
|
15天前
|
前端开发 Unix 测试技术
揭秘!前端大牛们如何高效管理项目,确保按时交付高质量作品!
【10月更文挑战第30天】前端开发项目涉及从需求分析到最终交付的多个环节。本文解答了如何制定合理项目计划、提高团队协作效率、确保代码质量和应对项目风险等问题,帮助你学习前端大牛们的项目管理技巧,确保按时交付高质量的作品。
28 2
|
1月前
|
前端开发 JavaScript 应用服务中间件
linux安装nginx和前端部署vue项目(实际测试react项目也可以)
本文是一篇详细的教程,介绍了如何在Linux系统上安装和配置nginx,以及如何将打包好的前端项目(如Vue或React)上传和部署到服务器上,包括了常见的错误处理方法。
296 0
linux安装nginx和前端部署vue项目(实际测试react项目也可以)
|
27天前
|
缓存 前端开发 JavaScript
前端架构思考:代码复用带来的隐形耦合,可能让大模型造轮子是更好的选择-从 CDN 依赖包被删导致个站打不开到数年前因11 行代码导致上千项目崩溃谈谈npm黑洞 - 统计下你的项目有多少个依赖吧!
最近,我的个人网站因免费CDN上的Vue.js包路径变更导致无法访问,引发了我对前端依赖管理的深刻反思。文章探讨了NPM依赖陷阱、开源库所有权与维护压力、NPM生态问题,并提出减少不必要的依赖、重视模块设计等建议,以提升前端项目的稳定性和可控性。通过“left_pad”事件及个人经历,强调了依赖管理的重要性和让大模型代替人造轮子的潜在收益
|
1月前
|
前端开发 JavaScript 开发工具
前端代码规范和质量是确保项目可维护性、可读性和可扩展性的关键(三)
前端代码规范和质量是确保项目可维护性、可读性和可扩展性的关键(三)
34 0
|
1月前
|
Web App开发 前端开发 JavaScript
前端代码规范和质量是确保项目可维护性、可读性和可扩展性的关键(二)
前端代码规范和质量是确保项目可维护性、可读性和可扩展性的关键(二)
48 0
|
1月前
|
Web App开发 移动开发 前端开发
前端代码规范和质量是确保项目可维护性、可读性和可扩展性的关键(一)
前端代码规范和质量是确保项目可维护性、可读性和可扩展性的关键(一)
46 0
|
1月前
|
前端开发 API 开发者
🥇前端宝藏:多项目掌握技能的冒险之旅🏆
在前端开发的学习旅程中,实践是提升技能的关键。本文介绍了多个前端项目,包括计算器、天气应用、经典游戏等,涵盖了从React到Svelte的各种技术栈。每个项目都附有在线演示和源代码,旨在帮助读者深入理解实现细节,激励更多人参与实际项目开发。通过这些项目,读者可以将理论知识转化为实践,拓展职业机会。
17 0