微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Jsonp跨域获取json数据原理

其实 jsonp 是个很简单的一个东西。
主要是利用了 <script/> 标签对 javascript 文档的动态解析来实现。(其实也可以用eval函数

来个超简单的例子:

首先是准备客户端的代码

  1. <spanstyle="font-size:18px;"><!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  2. <htmlxmlns="http://www.w3.org/1999/xhtml">
  3. <head>
  4. <title>TestJsonp</title>
  5. <scripttype="text/javascript">
  6. functionjsonpCallback(result)
  7. {
  8. alert(result.msg);
  9. }
  10. </script>
  11. <scripttype="text/javascript"src="http://crossdomain.com/jsonServerResponse?jsonp=jsonpCallback"></script>
  12. </head>
  13. <body>
  14. </body>
  15. </html></span>

其中 jsonCallback 是客户端注册的,获取跨域服务器上的json数据后,回调的函数
http://crossdomain.com/jsonServerResponse?jsonp=jsonpCallback
这个 url 是跨域服务器取 json 数据的接口,参数为回调函数的名字,返回的格式为

  1. jsonpCallback({msg:'thisisjsondata'})

Jsonp原理: 首先在客户端注册一个callback,然后把callback的名字传给服务器。 此时,服务器先生成 json 数据。 然后以 javascript 语法的方式,生成一个function,function 名字就是传递上来的参数 jsonp. 最后将 json 数据直接以入参的方式,放置到 function 中,这样就生成了一段 js 语法的文档,返回给客户端。 客户端浏览器,解析script标签,并执行返回的 javascript 文档,此时数据作为参数,传入到了客户端预先定义好的 callback 函数里.(动态执行回调函数

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐