JSON和JSONP
2015-11-18 15:40
411 查看
转载来自:http://www.jb51.net/article/57728.htm
http://kb.cnblogs.com/page/139725/
一 概念
1. JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,用于在浏览器和服务器之间交换信息。
//JSON
{
“name”: “sb”
}
2. JSONP(JSON With Padding),就是打包在函数调用中的的JSON(或者包裹的JSON)。JSON是一种数据格式,JSONP是一种数据调用方式。
//JSONP
callback({
“name”: “sb”
})
二 应用
出于安全考虑,脚本(AJAX)不能访问非本域的内容。但是,静态资源是不受域策略限制的,可以加载任意域的脚本、样式、图片等静态资源,JSOP就是利用这种原理来实现跨域获取数据的。
1. 第一个例子
//在Web页面中包含showPrice函数和参数
<script type="text/javascript">
function showPrice(data) {
alert("Symbol: " + data.symbol + ", Price: " + data.price);
}
</script>
<script type="text/javascript">showPrice({symbol: 'IBM', price: 91.42});</script>
2. 第二个例子
jsonp.html页面代码如下:
remote.js文件代码如下:
http://kb.cnblogs.com/page/139725/
一 概念
1. JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,用于在浏览器和服务器之间交换信息。
//JSON
{
“name”: “sb”
}
2. JSONP(JSON With Padding),就是打包在函数调用中的的JSON(或者包裹的JSON)。JSON是一种数据格式,JSONP是一种数据调用方式。
//JSONP
callback({
“name”: “sb”
})
二 应用
出于安全考虑,脚本(AJAX)不能访问非本域的内容。但是,静态资源是不受域策略限制的,可以加载任意域的脚本、样式、图片等静态资源,JSOP就是利用这种原理来实现跨域获取数据的。
1. 第一个例子
//在Web页面中包含showPrice函数和参数
<script type="text/javascript">
function showPrice(data) {
alert("Symbol: " + data.symbol + ", Price: " + data.price);
}
</script>
<script type="text/javascript">showPrice({symbol: 'IBM', price: 91.42});</script>
2. 第二个例子
jsonp.html页面代码如下:
<!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 localHandler = function(data){ alert('我是本地函数,可以被跨域的remote.js文件调用,远程js带来的数据是:' + data.result); }; </script> <script type="text/javascript" src="http://remoteserver.com/remote.js"></script> </head> <body> </body> </html>
remote.js文件代码如下:
localHandler({"result":"我是远程js带来的数据"});
相关文章推荐
- js立即执行函数
- js-调用百度地图api
- JavaEE_JavaScript__前台(Jsp页面) + 后台数据处理(Servlet),与javaScript的过程的处理
- JS 报错 “Uncaught SyntaxError: Unexpected token o”
- JS UrlEncode UrlDecode
- JScrollPane控件中添加其他控件的问题&&JScrollPane设置滚动条&&调整滚动速度
- JScrollPane控件中添加其他控件的问题&&JScrollPane设置滚动条&&调整滚动速度
- JS中设置backgroun-position不成功的问题
- js中使用jstl中得到的值
- JSTL详解
- 共享日常收集JS正则表达式(JavaScript regular expression)
- js动态绑定事件
- JavaScript中的this
- js删除数组中某一项或几项的几种方法
- 无缝滚动scrollLeft
- extjs store中数据转换成json
- JavaScript ~~~~~ 正则匹配
- javascript实现添加附件功能的方法
- XML转JSON
- 用jstl的if或when标签判断字符串是否为空