JSONP原理及jQuery中的使用

JSONP原理

JSON和JSONP

  JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,用于在浏览器和服务器之间交换信息。

  JSONP(JSON With Padding),就是打包在函数调用中的的JSON(或者包裹的JSON)。

  JSON是一种数据格式,JSONP是一种数据调用方式。

1 //JSON
2
3 {
4
5 “name”: “sb”
6
7 }
1 //JSONP
2
3 callback({
4
5 “name”: “sb”
6
7 })

  出于安全考虑,脚本(AJAX)不能访问非本域的内容。但是,静态资源是不受域策略限制的,可以加载任意域的脚本、样式、图片等静态资源,JSOP就是利用这种原理来实现跨域获取数据的。

例1:

1 //定义shoPrice函数
2 function showPrice(data) {
3     alert("Symbol: " + data.symbol + ", Price: " + data.price);
4 }
1 //在Web页面中包含showPrice函数和参数
2 <script type="text/javascript">
3 function showPrice(data) {
4     alert("Symbol: " + data.symbol + ", Price: " + data.price);
5 }
6 </script>
7 <script type="text/javascript">showPrice({symbol: ‘IBM‘, price: 91.42});</script>

  本例展示了如何将静态JSON数据作为参数调用JavaScript函数。

例2:

  第一种的函数调用完全可以写在一个js文件中放在服务器上,用script标签加载到页面,而且这个标签可以动态地创建。

 1 <script type="text/javascript">
 2 // This is our function to be called with JSON data
 3 function showPrice(data) {
 4     alert("Symbol: " + data.symbol + ", Price: " + data.price);
 5 }
 6
 7 var url = “remote.js”; // 外部脚本的URL
 8 // 动态插入脚本
 9 var script = document.createElement(‘script‘);
10 script.setAttribute(‘src‘, url);
11
12 // 加载script
13 document.getElementsByTagName(‘head‘)[0].appendChild(script);
14 </script>

remote.js的内容和之前在标签里写的一样是:

1 showPrice({symbol: ‘IBM‘, price: 91.42});

  动态插入的JavaScript代码,将要传递的JSON数据作为参数,showPrice函数调用语句的参数。

  那么问题来了,每次获取到数据都调用showPrice函数吗?这就需要前后端程序猿做好约定,当然这样有很多不便,尤其是对于开放接口给公众开发的情况。JSOP这样处理:支持前端传递一个回调函数名参数,后端接收回调函数名参数,然后生成对该函数的调用,将JSON数据作为参数传递,在到达客户端时将其插入页面开始执行。

例3:

  动态插入代码,带有callback参数:

 1  <script type="text/javascript">
 2  // This is our function to be called with JSON data
 3  function showPrice(data) {
 4      alert("Symbol: " + data.symbol + ", Price: " + data.price);
 5  }
 6
 7 var url = “remote.js?callback=‘showPrice‘”; // 外部脚本的URL
 8
 9 // 动态插入脚本
10 var script = document.createElement(‘script‘);
11 script.setAttribute(‘src‘, url);
12
13 // 加载script
14 document.getElementsByTagName(‘head‘)[0].appendChild(script);
15  </script>

后端用PHP实现的JSONP服务的代码片段:

1 $jsonData = getDataAsJson($_GET[‘symbol‘]);
2 echo $_GET[‘callback‘] . ‘(‘ . $jsonData . ‘);‘;
3 // 打印: showPrice({"symbol" : "IBM", "price" : "91.42"});

很好的契合了JSONP的定义,打包在函数调用中的JSON数据。

以上几个例子来自:

使用 JSONP 实现跨域通信,第 1 部分: 结合 JSONP 和 jQuery 快速构建强大的 mashup

在jQuery中使用JSONP

  AJAX和JSONP在jQuery中的调用方式看起来极为相像,千万不要被这种现象迷惑,它们本质上有很大不同。AJAX是通过XMLHttpRequest对象获取非页面内容,而JSONP是动态的添加<script>标签来调用服务器脚本。虽然jQuery把JSONP作为AJAX的一种形式进行了封装,但JSONP并不是AJAX的一种形式或一种特例。

 1
 2 $.ajax({
 3     url: "http://query.yahooapis.com/v1/public/yql",
 4
 5     jsonpCallback: "showPrice",
 6     jsonp: "callback",
 7
 8     // tell jQuery we‘re expecting JSONP
 9     dataType: "jsonp",
10
11
12     data: {
13         q: "select title,abstract,url from search.news where query=\"cat\"",
14         format: "json"
15     },
16
17     // work with the response
18     success: function( data ) {
19         console.log( data ); // server response
20     }
21 });

参数解释:

jsonp,

  重写jsonp请求中的回调函数的名称。至俄格值用来替代“callback=?”这种GET或POST请求URL参数里的“callback”部分,例如{jsonp:‘onJsonPLoad‘}会导致“onJsonPLoad”传递给服务器。

jsonpCallback,

  为jsonp指定一个回调函数名。这个值将用来取代jQuery自动生成的随机函数名。这主要用来让jQuery生成度独特的函数名,这样管理请求更容易,也能方便地提供回调函数和错误处理。你也可以在想让浏览器缓存GET请求的时候,指定这个回调函数名。但是实际使用过程中,并不用写回调函数,比如此例中的showPrice,不写也不会报错,因为jQuery在处理JSONP的时候,自动帮你生成回调函数并且把数据取出来共success方法调用。可能像这样:

function success_jsonpCallback(data) { success(data); }

其他参数可以到jQuery官网查询:http://api.jquery.com/jquery.ajax/

参考:

js使用JSONP、VAR实现前端跨域

说说JSON和JSONP,也许你会豁然开朗,含jQuery用例

知乎:JSONP的工作原理是什么?

working with JSONP

跨域请求之jQuery的ajax jsonp的使用解惑

时间: 2024-08-05 23:41:29

JSONP原理及jQuery中的使用的相关文章

JavaScript事件委托原理及Jquery中的事件委托

概念 事件委托,通俗来说就是将元素的事件委托给它的父级或者更外级元素处理. 事件流 事件流描述的是从页面中接收事件的顺序. 事件冒泡:事件开始由最具体的元素接收,然后逐级向上传播到较为不具体的节点(或文档). 事件捕获:事件开始由不太具体的节点接收,然后逐级向下传播到最具体的节点.它与事件冒泡是个相反的过程. DOM2级事件规定的事件流包括三个阶段: 事件捕获 目标阶段 事件冒泡 原理 事件委托就是利用事件冒泡机制实现的. 假设有一个列表,要求点击列表项弹出对应字段. <ul id="my

浅析Ajax跨域原理及JQuery中的实现分析

AJAX 的出现使得网页可以通过在后台与服务器进行少量数据交换,实现网页的局部刷新.但是出于安全的考虑,ajax不允许跨域通信.如果尝试从不同的域请求数据,就会出现错误.如果能控制数据驻留的远程服务器并且每个请求都前往同一域,就可以避免这些安全错误.但是,如果仅停留在自己的服务器上,Web 应用程序还有什么用处呢?如果需要从多个第三方服务器收集数据时,又该怎么办?  一.关于ajax跨域的思考 1.Ajax为什么不能跨域?到底是卡在哪个环节了?(下面项目中具体说,这里先说下结论). Ajax其实

jQuery中利用JSONP解决AJAX跨域问题

写在前面 跨域的解决方案有多种,其中最常见的是使用同一服务器下的代理来获取远端数据,再通过ajax进行读取,而在这期间经过了两次请求过程,使得获取数据的效率大大降低,这篇文章蓝飞就为大家介绍一下解决跨域问题的一种比较通用的方案——JSONP. 什么是跨域? 简单的来说,出于安全方面的考虑,页面中的JavaScript无法访问其他服务器上的数据,即“同源策略”.而跨域就是通过某些手段来绕过同源策略限制,实现不同服务器之间通信的效果. 具体策略限制情况可看下表: URL 说明 允许通信 http:/

jquery中链式调用原理

(1).链式调用 $("#mybtn").css("width","100px") .css("height","100px") .css("background","red"); (2).在对属性进行操作时建议使用JSON形式控制样式 $("#mybtn").css({    width:200,    height:"200"

jQuery 中 data 方法的实现原理

前言:jQuery 作为前端使用最多最广泛的 JS 库,其源码每个 JSer 都应该研究一下.早就打算看却一直被各种事拖着,上次某公司面试时被问到 jQuery 中 data 方法是如何实现的,结果答不上来懊悔不已.现在终于下决心开始看 jQuery 的源码,就从 data 方法开始.本人也是前端新手,如果文章中有理解不当或者错误之处,欢迎留言指出,3Q~ jQuery 版本为 1.8.2 data() 的使用方法 // 向一个 dom 元素绑定数据 $("#header").data

jquery中关于对象类型的判断原理

class2type[ core_toString.call(obj) ] jquery中关于对象类型的判断原理 jquery源码中关于类型判断的工具函数为type,调用方法为$.type()或者jQuery.type(),关于type函数的实现为: 1 type: function( obj ) { 2 if ( obj == null ) { 3 return String( obj ); 4 } 5 // Support: Safari <= 5.1 (functionish RegExp

jQuery中$.proxy()的原理和使用

jQuery.proxy(),接受一个函数,然后返回一个新函数,并且这个新函数始终保持了特定的上下文(context )语境. jQuery.proxy( function, context ) function将要改变上下文语境的函数. context函数的上下文语境(`this`)会被设置成这个 object 对象. jQuery.proxy( context, name ) context函数的上下文语境会被设置成这个 object 对象. name将要改变上下文语境的函数名(这个函数必须

关于JQuery中$.data绑定数据原理或逻辑

问题: JQuery中,对于.data([key],[value])函数,当使用其进行数据绑定时,假设要绑定的数据是“引用数据类型”,也就是对象:那么.data函数绑定的是该对象的副本还是该对象的一个引用?下面通过以下小例子来测试下: 1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4 <meta charset="UTF-8"> 5 <title>Test<

window.onload和JQuery中$(function(){})的区别即其实现原理

一.区别 window.onload是在DOM树加载完成之后(DOM树加载完不代表全部资源加载完,例如图片,音频和视频等还没加载)执行的. 在Jquery中$(function(){ })和$(document).ready(function(){ })的效果是一样,是在DOM树加载完成之后就会执行.所以$(document).ready(function(){ })是比window.onload要先执行的.那么JQuery中$(document).ready(function(){ })用原生