关于ajax ,json

来源:互联网 发布:洋码头mac是正品吗 编辑:程序博客网 时间:2024/06/05 17:38

做级联下拉菜单的时候基本就用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对象.

 

 


  

0 0
原创粉丝点击