关于JSON与JSONP简单总结


Posted in Javascript onAugust 16, 2016

一、什么是json

JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式。 易于人阅读和编写。同时也易于机器解析和生成。 它基于JavaScript Programming Language, Standard ECMA-262 3rd Edition - December 1999的一个子集。 JSON采用完全独立于语言的文本格式,但是也使用了类似于C语言家族的习惯(包括C, C++, C#, Java, JavaScript, Perl, Python等)。 这些特性使JSON成为理想的数据交换语言。

二、什么是JSONP

JSONP(JSON with Padding)是资料格式 JSON 的一种“使用模式”,可以让网页从别的网域要资料。另一个解决这个问题的新方法是跨来源资源共享。

JSONP

定义:是一种跨域数据访问方式。

作用与原理:在客户端声明 callback回调函数之后,客户端通过script标签向服务器跨域请求数据,然后服务端返回相应的JSON数据并动态执行回调函数。

在jQuery中使用如下:

//JQuery JSONP Support 
var url = "http://192.168.0.103:12075/api/test.aspx?id=1&callback=?"; 
jQuery.getJSON(url, function(data){ 
// 处理返回的json 数据
alert("name:" + data.name+ ", Price:" + data.price); 
});

调用 webservices 使用如下:

$.getJSON( 
"http://192.168.0.103:12050/services/WebService1.asmx/ws/test?callback=?", 
{ name: "jim", time: "2pm" }, 
function(data) {
//处理返回的json 数据
alert(decodeURI(data.msg));
});

服务器端(webservices 后台代码):

[WebMethod] 
public void ws(string name,string time) { 
HttpRequest Request = HttpContext.Current.Request; 
string callback = Request["callback"]; 
HttpResponse Response = HttpContext.Current.Response; 
Response.Write(callback + "({msg:' 返回数据'})"); 
Response.End(); 
}

总结JSONP:

两点需注意:

1.不提供错误处理机制,有数据返回,没有不显示内容,获得一个404的错误

2.如果使用了不信任的服务会造成很大的安全隐患。

JSON

与XML相比,JSON是一个轻量级的数据交换格式。易于人阅读和编写。同时也易于机器解析和生成,分两种:对象(使用下面点语法获取属性值)和数组(遍历数组,索引获取)。

1.把 JSON 文本转换为 JavaScript 对象

从 web 服务器上读取 JSON 数据,将 JSON 数据转换为 JavaScript 对象,然后在网页中使用该数据.

JavaScript 函数 eval() 可用于将 JSON 文本转换为 JavaScript 对象。必须把文本包围在括号中,这样才能避免语法错误。

即:通过eval函数将json串转换为json对象,然后可以通过两种方法访问:

关于JSON与JSONP简单总结

服务器端:

// user 实体对象,后台序列化成对象,供前台使用
string strJson = Newtonsoft.Json.JsonConvert.SerializeObject(user);
context.Response.Write(strJson);

前台:

$.getJSON( 
"webdata/test.aspx",
function(data) {
//获取对象里面的一个值(username:用户姓名)
$("#divmessage").text(data.username);
}
);

2. 数组 获取

packJson = [
{"name":"nikita", "password":"1111"},
{"name":"tony", "password":"2222"}
];

循环遍历:

for(var i = 0; i < packJson.length; i++){
alert(packJson[i].name + " " + packJson[i].password);
}

以上所述是小编给大家介绍的关于JSON与JSONP简单总结,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
Jquery在IE7下无法使用 $.ajax解决方法
Nov 11 Javascript
网页中的图片的处理方法与代码
Nov 26 Javascript
js 变量类型转换常用函数与代码[比较全]
Dec 01 Javascript
jQuery实现的立体文字渐变效果
May 17 Javascript
js实现鼠标拖动图片并兼容IE/FF火狐/谷歌等主流浏览器
Jun 06 Javascript
javascript显示用户停留时间的简单实例
Aug 05 Javascript
详解JavaScript的流程控制语句
Nov 30 Javascript
常用的js验证和数据处理总结
Aug 02 Javascript
概述jQuery的元素筛选
Nov 23 Javascript
CSS+jQuery实现简单的折叠菜单
Dec 20 Javascript
使用Node.js实现简易MVC框架的方法
Aug 07 Javascript
JS+DIV实现拖动效果
Feb 11 Javascript
json与jsonp知识小结(推荐)
Aug 16 #Javascript
浅谈JS继承_借用构造函数 &amp; 组合式继承
Aug 16 #Javascript
JS读写CSS样式的方法汇总
Aug 16 #Javascript
浅谈JS继承_寄生式继承 &amp; 寄生组合式继承
Aug 16 #Javascript
jQuery EasyUI Tab 选项卡问题小结
Aug 16 #Javascript
jQuery3.0中的buildFragment私有函数详解
Aug 16 #Javascript
js 自带的 map() 方法全面了解
Aug 16 #Javascript
You might like
150kHz到30Mhz完全冲浪手册
2020/03/20 无线电
第十四节--命名空间
2006/11/16 PHP
php中使用ExcelFileParser处理excel获得数据(可作批量导入到数据库使用)
2010/08/21 PHP
php生成图片验证码
2015/06/09 PHP
android上传图片到PHP的过程详解
2015/08/03 PHP
PHP中常用的数组操作方法笔记整理
2016/05/16 PHP
PHP队列场景以及实现代码实例详解
2021/02/26 PHP
你需要知道的JavsScript可以做什么?
2007/06/29 Javascript
javascript删除option选项的多种方法总结
2013/11/22 Javascript
window.onerror()的用法与实例分析
2016/01/27 Javascript
Vue2.0实现将页面中表格数据导出excel的实例
2017/08/09 Javascript
浅谈ES6 模板字符串的具体使用方法
2017/11/07 Javascript
详解创建自定义的Angular Schematics
2018/06/06 Javascript
Vue中computed、methods与watch的区别总结
2019/04/10 Javascript
JavaScript 处理树数据结构的方法示例
2019/06/16 Javascript
vue 项目中当访问路由不存在的时候默认访问404页面操作
2020/08/31 Javascript
详解vue父子组件状态同步的最佳方式
2020/09/10 Javascript
vue实现简单的登录弹出框
2020/10/26 Javascript
JavaScript async/await原理及实例解析
2020/12/02 Javascript
Python中实现结构相似的函数调用方法
2015/03/10 Python
Python实现将罗马数字转换成普通阿拉伯数字的方法
2017/04/19 Python
python实现自动发送邮件发送多人、群发、多附件的示例
2018/01/23 Python
python监控进程脚本
2018/04/12 Python
python Canny边缘检测算法的实现
2020/04/24 Python
台湾旅游网站:灿星旅游
2018/10/11 全球购物
财务工作者先进事迹材料
2014/01/17 职场文书
总经理司机岗位职责
2014/02/06 职场文书
教师个人鉴定材料
2014/02/08 职场文书
聚美优品励志广告词
2014/03/14 职场文书
禁止酒驾标语
2014/06/25 职场文书
2014年最新大专生职业生涯规划书范文
2014/09/13 职场文书
群众路线教育实践活动心得体会(教师)
2014/10/31 职场文书
2015新学期校长寄语(3篇)
2015/03/25 职场文书
合同纠纷调解书
2015/05/20 职场文书
幼儿园春季开学通知
2015/07/16 职场文书
机械生产实习心得体会
2016/01/22 职场文书