Ajax的数据类型

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

前面在Ajax的使用中,遇到了一个这样的问题:界面开发出来是用在手机上使用的,然而数据是通过服务器提供的API,在界

面上使用JQuery的Ajax来调用数据,开始怎么也调用不到,而且不报错误,后面现在浏览器测试好了,在放手机上加载本地的面。


1、服务器关键代码如下:

/**
*@seeHttpServlet#doGet(HttpServletRequestrequest,HttpServletResponse
*response)
*/
protectedvoiddoGet(HttpServletRequestrequest,
HttpServletResponseresponse)throwsServletException,IOException{
response.setContentType("text/javascript");//这个要注意
PrintWriterout=response.getWriter();
Stringcallback=request.getParameter("callback");
out.print(callback
+"([{name:'John',age:'19'},{name:'joe',age:'20'}])");
System.out.println("callback="+callback);
out.flush();
out.close();
}

2、界面关键代码;
$.ajax({
url:"http://localhost:8081/JsonpServer/JsonpServlet",
dataType:"jsonp",
jsonp:"callback",//传递给请求处理程序或页面的,用以获得jsonp回调函数名的参数名(默认为:callback),需和服务器端一致
jsonpCallback:"person",//自定义的jsonp回调函数名称,默认为jQuery自动生成随机函数
success:function(json){
//alert(json[0].name);
}
});
//相当于重写success后执行函数自定义为person)
functionperson(json){
alert("Iampersonfunction...");
alert(json[0].name);
}

分析:
最开始没有效果 dataType:"json",所以测试了很久都没有出来,后面修改dataType:"jsonp", 就可以使用了。原因是 dataType 为 json 数据格式的时候,不能跨域访问,jsonp 是跨域访问的。

猜你在找的Ajax相关文章