php ajax 购物车类,AJAX_Ajax修改购物车示例,1.购物车类的设计 ShoppingCartI - phpStudy...

Ajax修改购物车示例

1.购物车类的设计

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;

});

});

相关阅读:

Win8.1系统关机命令变成重启问题解决方法

CentOS 6误删除的boot分区该如何还原恢复

Win10开机声音没有了怎么办?Win10开机声音设置方法图文详解

C#中的is和as操作符区别小结

C#实现客户端弹出消息框封装类实例

JavaScript 32位整型无符号操作示例

CSS行内元素和块级元素的居中实例分析

JavaScript使ifram跨域相互访问及与PHP通信的实例

浅析Android 手机卫士设备管理权限锁屏

在Linux系统中限制CPU占用率的教程

Android判断是否为飞行模式简单方法

浅析java 的 static 关键字用法

JavaScript sub方法入门实例(把字符串显示为下标)

JSP+jquery使用ajax方式调用json的实现方法

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
根据提供的引用内容,D:\phpstudy_pro\WWW\member\ajax_membergroup.php是一个位于D盘phpstudy_pro目录下WWW文件夹中的ajax_membergroup.php文件。它可能是一个用于处理会员分组的ajax请求的文件。根据引用中的config/template.php文件中的配置信息,该文件可能会返回一个html后缀的响应。根据引用中的代码,该文件中可能包含了一些使用session和cookie进行身份认证的代码。而根据引用中的描述,phpStudy是一个集成了Apache、PHP、MySQL等工具的PHP调试环境,所以D:\phpstudy_pro\WWW\member\ajax_membergroup.php可能是在phpStudy环境中的一个文件。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [php学习(三):近几年来,不断发展的ThinkPhp框架(TP6)](https://blog.csdn.net/qq_50792097/article/details/126417976)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [phpstudy_pro.zip](https://download.csdn.net/download/CUFEECR/12340408)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值