关于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对象.

 

 


  

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值