关于ajax ,json

前端之家收集整理的这篇文章主要介绍了关于ajax ,json前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

做级联下拉菜单的时候基本就用ajax了

eg:function selectHdept(){
var hosptial;
var hdept;
hospital=$("#yyhospital").attr("value");
hdept=$("#yyhdept").attr("value");
$.ajax({
url:"yysq!getexpert.action",
type:"GET",
data:{'hospitalId' :hospital,'hdeptName' :encodeURIComponent(hdept)},
dateType:"json",
success:function(result){
if(result==null||result.length==2){
$("#expert").empty();
$("#expert").append("<option value=''>-----全部-----</option>");
return;}
$("#expert").empty();
$("#expert").append("<option value=''>-----全部-----</option>");
var jsonObject=eval("("+result+")");
for(var e in jsonObject){

$("#expert").append("<option value='"+jsonObject[e][0]+"'>"+jsonObject[e][1]+"</option>");
}
}
});
}

其中的result是从后台返回的,在struts2的框架里感觉还是用

HttpServletResponse response = ServletActionContext.getResponse();
response.setContentType("text/html; charset=utf-8");
response.setHeader("Cache-Control","no-cache");
hdeptName=URLDecoder.decode(hdeptName,"utf-8");
List list=this.zzyyService.getExpert(hospitalId,hdeptName);
JSONArray jsArr = JSONArray.fromObject(list);
response.getWriter().append(jsArr.toString());

比较方便,其中的list可能是数组,也可能是对象数组

普通数组传到前端的result直接是json数组格式,对象数组传到前端是string格式

这时候需要用到强大eval函数将它转化为json数据对象。

list如果是对象数组集合list<object[]>,可以把object[]放入map结构,这样转换后在前台就可以得到json对象.

原文链接:https://www.f2er.com/ajax/164501.html

猜你在找的Ajax相关文章