现在做的课题要实现在一个没有部署在服务器上的网页中,使用ajax来加载已经 部署在服务器上的一个服务提供的数据。
先看静态页面的代码:
看http://localhost/c.txt的返回:
success_jsonpCallback({"name":"zoer"})
上面这一行的返回数据。其中(之前的是回调函数的名字。后面的内容是返回数据。
用浏览器打开html,点击gogogo,就能alert出来zoer这个名字。
---------------------------------------------------------------------------------------------------
这里使用了jq的jsonp功能。看介绍:
如果获取的数据文件存放在远程服务器上(域名不同,也就是跨域获取数据),则需要使用jsonp类型。使用这种类型的话,会创建一个查询字符串参数 callback=? ,这个参数会加在请求的URL后面。服务器端应当在JSON数据前加上回调函数名,以便完成一个有效的JSONP请求。意思就是远程服务端需要对返回的数据做下处理,根据客户端提交的callback的参数,返回一个callback(json)的数据,而客户端将会用script的方式处理返回数据,来对json数据做处理。JQuery.getJSON也同样支持jsonp的数据方式调用。
---------------------------------------------------------------------------------------------------
好处:
能跨域取得数据。
坏处:
返回值的前面必须是回调函数的名字。所以远程函数必须能够提供这样的内容。