SpringMvc后台传递Map到前台并解析

SpringMvc后台程序:

/**
 * 根据ids查找商品
 */
@RequestMapping(value = "/cartItems", method = RequestMethod.GET,produces = "application/json; charset=utf-8")
public @ResponseBody
String cartItems() {
	JSONObject json = new JSONObject();
	List<HashMap<String,Object>> list = new ArrayList<HashMap<String,Object>>();
	Cart cart = cartService.getCurrent();
	if(cart != null)
	{
		Set<CartItem> alls = cart.getCartItems();
		Iterator<CartItem> iter = alls.iterator();
		while(iter.hasNext())
		{
			HashMap<String,Object> hm = new HashMap<String,Object>();   //最外层,父节点
			CartItem ci = iter.next();
			hm.put("id", ci.getId());//id属性  ,数据传递  
			hm.put("name", ci.getProduct().getName()); //name属性,显示节点名称  
			hm.put("image",ci.getProduct().getThumbnail()==null?"":ci.getProduct().getThumbnail());
			hm.put("count", ci.getQuantity());
			hm.put("price", ci.getProduct().getPrice());
			list.add(hm);
		}
	}	
	JSONArray arr = new JSONArray(list);
	try {
		json.put("success", true);
		json.put("arr", arr);
	} catch (JSONException e) {
		// TODO Auto-generated catch block
		e.printStackTrace();
	}
	return arr.toString();
}


前台代码:

//取得购物车项
$.ajax({
	url: "${base}/cart/cartItems.jhtml",
	type: "GET",
	dataType: "json",
	traditional: true,
	cache: false,
	success: function(data) {
		var msg = eval(data);
		$.each(msg, function (index, item) {  
			 //循环获取数据    
			 var id = msg[index].id;  
			 var name = msg[index].name;
			 var image = msg[index].image;
			 var count = msg[index].count;
			 var price = msg[index].price;
			 [@compress single_line = true]
				var html = 
					'<dt><a href="#"><img src="${base}'+image+'"<\/a><\/dt><dd><p>'+name+'<\/p><h1>¥'+price+'<span>×'+count+'<\/span><a href="#">删除<\/a><\/h1><\/dd>';
			 [/@compress]
			$("#cartItems").append(html);
		});  
	}
});


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

甘蓝聊Java

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值