购物车案例ajax,Ajax改购物车示例

1.购物车类的设计

2020110709343634644.gif

ShoppingCartItem:书的封装,包括书名,数量,价格三个属性,以及对应的getter和setter方法。

ShoppingCart:购物车封装类,items为 Map ,以及加入购物车,得到购物车中书的总数量以及总价格三个函数。

2:jsp加入购物车,超链接中带入书名以及价格

您已经将

加入到购物车中,购物车中有

本书,总价格是

java

href="${pageContext.request.contextPath}/addToCart?id=java&price=100">加入购物车

ajax

href="${pageContext.request.contextPath}/addToCart?id=ajax&price=200">加入购物车

jquery

href="${pageContext.request.contextPath}/addToCart?id=jquery&price=300">加入购物车

3:addToCart -----servlet的设计

步骤如下:

1) :获取请求参数 id(bookName),price,是从jsp网页中的超链接来获取的

2):在session中获取购物车对象,如果session属性中没有购物车,则新版建一个购物车对象放置在session属性中

3) : 加入购物车操作Shopping.addToCart(bookName, price);

4):想ajax传递Json对象,该对象包括 :{""bookName"":"totalBookNumber","totalMoney" },若从服务器端返回json对象,则属性名必须使用双引号!!

5):响应json请求,response.getWriter().print(json);

public class AddToCartServlet extends HttpServlet {

public void doGet(HttpServletRequest request, HttpServletResponse response)

throws ServletException, IOException {

this.doPost(request, response);

}

public void doPost(HttpServletRequest request, HttpServletResponse response)

throws ServletException, IOException {

//1:获取请求参数 id(bookName),price

String bookName =request.getParameter("id");

int price =Integer.parseInt(request.getParameter("price"));

//2:获取购物车对象,在session中

ShoppingCart sc=(ShoppingCart) request.getSession().getAttribute("sc");

if(sc==null){

sc=new ShoppingCart();

request.getSession().setAttribute("sc",sc);

}

//3;将搜索的对象加入到购物车中

sc.addToCart(bookName, price);

//4:准备响应的Json对象:{""bookName"":"totalBookNumber","totalMoney" }

//若从服务器端返回json对象,则属性名必须使用双引号!!

StringBuilder sBuilder=new StringBuilder();

sBuilder.append("{")

.append("\"bookName\":\""+bookName+"\"")

.append(",")

.append("\"totalBookNumber\":\""+sc.getTotalBookNumber()+"\"")

.append(",")

.append("\"totalMoney\":\""+sc.getTotalMoney()+"\"")

.append("}");

//响应json请求

response.setContentType("text/javascript");

response.getWriter().print(sBuilder.toString());

}

}

上述中的用StringBuilder来拼接JSON字符串的方式可以借助第三方开源Jackson来简化实现:

String jsonStr=null;

ObjectMapper objectMapper=new ObjectMapper();

jsonStr=objectMapper.writeValueAsString(sc);

4:ajax接受从服务器传来的参数{""bookName"":"totalBookNumber","totalMoney" }

步骤:

1):为加入购物车这个超链接增加单击响应函数,并取消默认行为(return false)

2):通过 HTTP GET 请求载入 JSON 数据。$.getJSON(url, [data], [callback])

准备url.agrs,并在回调函数内部将购物车中的内容显示在Jsp网页中。

3):通过jquery中的hide(),show()方法,判断是不是第一使用购物车,如果是第一次使用,则jsp网页不显示购物车。

$(function(){

var isHasCart="${sessionScope.sc==null}";

if(isHasCart=="true"){

$("#cartstatus").hide();//隐藏显示的元素

}else{

$("#cartstatus").show(); //显示隐藏的匹配元素

$("#bookName").text("${sessionScope.sc.bookName}");

$("#totalBookNumber").text("${sessionScope.sc.totalBookNumber}");

$("#totalMoney").text("${sessionScope.sc.totalMoney}");

}

$("a").click(function(){

$("#cartstatus").show();

var url=this.href; //url属性

var agrs={"time":new Date()}; //时间戳

$.getJSON(url,agrs,function(data){

$("#bookName").text(data.bookName);

$("#totalBookNumber").text(data.totalBookNumber);

$("#totalMoney").text(data.totalMoney);

});

return false;

});

});

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值