首页 > 代码库 > ajax请求返回map,并遍历

ajax请求返回map,并遍历

最近老用到ajax请求数据,但是每次都遇到一点梗,浪费了些许时间,所以记录下来。

$.ajax({

        type: "POST",

url: "<%=path%>/account/queryRolesAndGroups.action",

data: "enterpriseId="+eid,

success: function(msg){

var obj=eval("(" + msg + ")");

$.each(obj.groupList, function(i,item){      

alert(item.groupName); 


  })

}

})  

})

一:发送请求到后台,然后后台通过各种操作,得到相应数据

  1,如果数据为 map,map中包含了多个list,

pw.print(net.sf.json.JSONObject.fromObject(returnMap.get("map")).toString());

后台这样转换,然后前台转换下:var obj=eval("(" + msg + ")");

就可以遍历里面的数据了(注意:net.sf.json.JSONArray.fromObject(returnMap.get("list")).toString())这样是转换单个集合时适用,然后前台直接遍历即可,不需要强转

success: function(msg){

alert(msg.length);

$.each(msg, function(i,item){      

alert(item.name); 


   })

}

。JSONArray转包含多个list的map时适用。


还有后台pw.print和pw.println的使用也要注意,当单个数据0,1来给后台判断时,pw.println会带换行符,永远不等于0,1.


response.setContentType("text/plain;charset=UTF-8");

     PrintWriter pw =response.getWriter();

这两句对返回乱码处理也要特别注意先后顺序。     PrintWriter pw =response.getWriter();在前的话,转换也不起作用!


ajax请求返回map,并遍历