JSONP原理

Posted unplugged

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JSONP原理相关的知识,希望对你有一定的参考价值。

1.jsonp原理

     通过动态创建script标签,利用script标签的src属性可以获取任何域下的js脚本,通过这个特性,

务器端不在返回json格式,而是返回一段某个函数的js代码的调用,实现了跨域。

      创建一个回调函数,然后在远程服务上调用这个函数并且将JSON 数据形式作为参数传递,完成回调

    将JSON数据填充进回调函数,这就是JSONP的JSON+Padding的含义吧。

2.具体实现

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
    <title></title>
    <script type="text/javascript">
    // 得到航班信息查询结果后的回调函数
    var flightHandler = function(data){
        alert(你查询的航班结果是:票价  + data.price +  元, + 余票  + data.tickets +  张。);
    };
    // 提供jsonp服务的url地址(不管是什么类型的地址,最终生成的返回值都是一段javascript代码)
    var url = "http://flightQuery.com/jsonp/flightResult.aspx?code=CA1998&callback=flightHandler";
    // 创建script标签,设置其属性
    var script = document.createElement(script);
    script.setAttribute(src, url);
    // 把script标签加入head,此时调用开始
    document.getElementsByTagName(head)[0].appendChild(script); 
    </script>
</head>
<body>

</body>
</html>

调用的url中传递了一个code参数,告诉服务器我要查的是CA1998次航班的信息,而callback参数则告诉服务器,我的本地回调函数叫做flightHandler,所以请把查询结果传入这个函数中进行调用。

OK,服务器很聪明,这个叫做flightResult.aspx的页面生成了一段这样的代码提供给jsonp.html

flightHandler({
    "code": "CA1998",
    "price": 1780,
    "tickets": 5
});

传递给flightHandler函数的是一个json,它描述了航班的基本信息

3.jquery实现jsonp调用

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
 <html xmlns="http://www.w3.org/1999/xhtml" >
 <head>
     <title>Untitled Page</title>
      <script type="text/javascript" src=jquery.min.js"></script>
      <script type="text/javascript">
     jQuery(document).ready(function(){ 
        $.ajax({
             type: "get",
             async: false,
             url: "http://flightQuery.com/jsonp/flightResult.aspx?code=CA1998",
             dataType: "jsonp",
             jsonp: "callback",//传递给请求处理程序或页面的,用以获得jsonp回调函数名的参数名(一般默认为:callback)
             jsonpCallback:"flightHandler",//自定义的jsonp回调函数名称,默认为jQuery自动生成的随机函数名,也可以写"?",jQuery会自动为你处理数据
             success: function(json){
                 alert(您查询到航班信息:票价:  + json.price +  元,余票:  + json.tickets +  张。);
             },
             error: function(){
                 alert(fail);
             }
         });
     });
     </script>
     </head>
  <body>
  </body>
 </html>

为什么我这次没有写flightHandler这个函数呢?因为jquery在处理jsonp类型的ajax时,自动帮你生成回调函数并把数据取出来供success属性方法来调用。

以上是关于JSONP原理的主要内容,如果未能解决你的问题,请参考以下文章

JSONP原理

jsonp的工作原理,观后必然懂!!!

JSONP跨域的原理解析

前端跨域之Jsonp实现原理及.Net下Jsonp的实现

转JSONP跨域的原理解析

剖析JSONP原理的小例子