Ajax使用Action中返回的Json数据的简单实例(一)

前端之家收集整理的这篇文章主要介绍了Ajax使用Action中返回的Json数据的简单实例(一)前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

实现原理:从Action中返回JSON格式的字符串,在ajax中获取到data,并将其转换成js的JSON数据,然后遍历

注:亦可在Java代码就转换为JSON格式,使用JSONArrayjsonArray=JSONArray.fromObject(string),写write(jsonArray.toString());这时在JS里就不需要使用eval()转换直接遍历

Struts.xml

<action name="myAjaxAction" class="myAction" method="myAjaxAction"><interceptor-ref name="mystack" /></action>
		


Action方法

public void myAjaxAction(){
		try{
			HttpServletResponse responses = ServletActionContext.getResponse();
			responses.setCharacterEncoding("utf-8");
			PrintWriter writer = responses.getWriter();
			//设置JSON数据,\"是转义符,实际内容为:[{name:"张三",age:12},{name:"李四",age:11},{name:"王五",age:13},{name:"小六",age:14}];
			String string="[{name:\"张三\",{name:\"李四\",{name:\"王五\",{name:\"小六\",age:14}]";
			writer.write(string);
			writer.flush();
			writer.close();
		}catch (Exception e) {
			// TODO: handle exception
		}
	}


HTML

<input type="button" value="测试JSON" onclick="ajaxJson()"/> 


JS代码

function ajaxJson(){
	$.ajax({
        type:"post",url:"myAjaxAction.action",async:true,success:function(data) {
        	var obj=eval("("+data+")");//将数据转换成json类型
			for(var i in obj){//遍历Json数据 
			    alert("姓名:"+obj[i].name+" 年龄:"+obj[i].age );  
			}
        },error:function(e) {
          alert("验证失败!");
        }
      });
}
原文链接:https://www.f2er.com/ajax/165999.html

猜你在找的Ajax相关文章