什么是Jsonp?
Jsonp(JSON with Padding)是json的一种“使用模式”,可以让网页从别的域名获取资料,即跨域读取数据。
原理
总所周知,<img>
、<script>
、<frame>
的src属性可以跨域访问服务器的资源,通过这些标签来实现jsonp的通讯方式。
为了便于客户端使用数据,逐渐形成了一种非正式传输协议,人们把它称作JSONP,该协议的一个要点就是允许用户传递一个callback
参数给服务端,然后服务端返回数据时会将这个callback
参数作为函数名来包裹住JSON数据,这样客户端就可以随意定制自己的函数来自动处理返回数据了。
AJAX的核心是通过XmlHttpRequest
获取非本页内容,而JSONP的核心则是动态添加<script>
标签来调用服务器提供的js脚本
<!DOCTYPE html>
<html>
<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>