JSON为什么那样红为什么要用json(另有洞天)


Posted in Javascript onDecember 26, 2012

json是1年内迅速红遍全球的东东。
现在解释JSON是什么,大家都会说我老土吧,这里我想分析一下json红的原因,我们又得到什么启示呢。
json是什么,json.org是一种简洁有效的数据载体,是一种用字符串表示复杂js对象的方式,后端好生成,前端0解释。
它的风行和一下几点原因离不开的。

持久化的风潮
persistence是javaEE5引入的重要模块。
php先天具备持久化特性每个变量都可以serialize()和unserialize()与字符串相互转化。
持久化带来最直接的好处就是复杂对象存储和传输,衡量持久化机制的优劣的重要标准是效率。

WEB2.0的推动
Ajax引发了Web2.0革命,其中的x是xml。在ajax中xml是作为前后台数据传输的载体的。
随着Web2.0的大规模应用,xml解释的效率问题就暴露无疑了,xml是具有非常严禁的结构,这造成了任何浏览器把xml装入,解释成javaScript可以访问的对象的过程是漫长的。而json是js默认支持的最简洁对象创建方式,js接收他是轻松加愉快的,所以在持久化数据传输的舞台上json靠效率取胜。

JSON本身易用
Ajax为什么一些老技术结合起来突然火了呢,因为易用。说白了自从上世纪有了DHTML,无刷新异步数据传输的解决方式绝不仅仅只有xmlHttpRequest一家。隐藏的iframe完全可以做到,而且一直也有人这么干。Ajax红了在于其易用性,所以几家领军企业对期的大规模应用引发Web2.0.
JSON同样易用,会了JSON之后我已经用var obj = {};var arr = []代替了var obj = new Object();var obj = new Array()。JSON是js中最简洁的对象定义方式,对于会js,用过eval()的朋友基本上没有什么学习成本。

以XML为代表的树形结构的风靡:
从数据结构的角度看xml的流行,因为xml是一颗树,树状的数据结构在像xml一样除了本身的内容节点再加上属性节点之后的威力如何大家都有体会,DOM是这种结构,UML是这种结构。
当我们用数据去描述客观世界的时候发现仅仅靠关系数据模型中的二维表已显笨拙,树形结构是更接近思维的一种,这也是人们在做会议记录时不在是notepad而使用freemind的原因。同样使用二维表,记录parentid的方式存储树的效率低下也给了LADP的发展空间。
说回来JSON,他是一种定义JS对象的方式,而JS中的Object是一树的形式组织的实体,所以JSON定义的对象在描述数据的功能上是足够的。

再说几个JSON相关的话题
JSON是解决xml效率问题的唯一途径么?
也不尽然,在本人不知道json之前,在使用div传输数据。
后台传到前台的是xmlHttp.responseText = '<div age="18" personid="007">lenel</div>';
然后前台接受数据时使用

function toDivElememnt(s){ 
var oDiv = document.createElement("div"); 
oDiv.innerHTML = s; 
oDiv = oDiv.firstChild; 
return oDiv; 
}

这个方法里我没有用js来解释json,而是用DOM来解释HTML串,这也是相当自然的,前面已经说过HTML串也是树状结构,我拿到oDiv之后就可以访问到age,personid等等属性了,效率也是相当可以的,呵呵。
这个不是我的原创啊,来自与我从前的Leader,牛人啊,良师益友。

JSON会代替XML么?
不会,在Ajax这个领域可能我们会搞Ajaj,但是XML如果只能干这点事那就不是XML了:)

还没用JSON么?
不要落伍了哈哈,当前主流的后台语言都有在后台生成、解析JSON的API,具体怎么用json,API去哪儿找http://www.json.org看看吧

我们真的得到什么启示么?
我还是没总结出来具体的,但是我认为语言是相通的,javaScript不能IOC么?

Javascript 相关文章推荐
javascript 关闭IE6、IE7
Jun 01 Javascript
jQuery学习基础知识小结
Nov 25 Javascript
基于jQuery中对数组进行操作的方法
Apr 16 Javascript
jquery图片放大功能简单实现
Aug 01 Javascript
javascript获取元素偏移量的方法有哪些
Jun 24 Javascript
基于jQuery实现滚动刷新效果
Jan 09 Javascript
Angular.JS中指令ng-if的注意事项小结
Jun 21 Javascript
vue-cli脚手架的安装教程图解
Sep 02 Javascript
微信小程序局部刷新触发整页刷新效果的实现代码
Nov 21 Javascript
使用imba.io框架得到比 vue 快50倍的性能基准
Jun 17 Javascript
使用xampp将angular项目运行在web服务器的教程
Sep 16 Javascript
使用uni-app开发微信小程序的实现
Dec 13 Javascript
JS操作Cookies包括(读取添加与删除)
Dec 26 #Javascript
js 调用本地exe的例子(支持IE内核的浏览器)
Dec 26 #Javascript
js鼠标滑过弹出层的定位IE6bug解决办法
Dec 26 #Javascript
window.open以post方式将内容提交到新窗口
Dec 26 #Javascript
JavaScript中json对象和string对象之间相互转化
Dec 26 #Javascript
jQuery-serialize()输出序列化form表单值的方法
Dec 26 #Javascript
js实现运动logo图片效果及运动元素对象sportBox使用方法
Dec 25 #Javascript
You might like
PHP 数组遍历方法大全(foreach,list,each)
2010/06/30 PHP
Function eregi is deprecated (解决方法)
2013/06/21 PHP
laravel 执行迁移回滚示例
2019/10/23 PHP
用tip解决Ext列宽度不够的问题
2008/12/13 Javascript
javascript css styleFloat和cssFloat
2010/03/15 Javascript
JavaScript 事件系统
2010/07/22 Javascript
JS前端框架关于重构的失败经验分享
2013/03/17 Javascript
jQuery的live()方法对hover事件的处理示例
2014/02/27 Javascript
JavaScript让网页出现渐隐渐显背景颜色的方法
2015/04/21 Javascript
javascript实现可拖动变色并关闭层窗口实例
2015/05/15 Javascript
jQuery实现仿腾讯迷你首页选项卡效果代码
2015/09/17 Javascript
Bootstrap3学习笔记(二)之排版
2016/05/20 Javascript
BootStrap Validator对于隐藏域验证和程序赋值即时验证的问题浅析
2016/12/01 Javascript
JavaScript正则获取地址栏中参数的方法
2017/03/02 Javascript
JavaScript中闭包的详解
2017/04/01 Javascript
Vue2.5 结合 Element UI 之 Table 和 Pagination 组件实现分页功能
2018/01/26 Javascript
vue2.0 datepicker使用方法
2018/02/04 Javascript
浅谈Vue下使用百度地图的简易方法
2018/03/23 Javascript
如何写好一个vue组件,老夫的一年经验全在这了(推荐)
2019/05/18 Javascript
Vuex 模块化使用详解
2019/07/31 Javascript
Vue中的nextTick作用和几个简单的使用场景
2021/01/25 Vue.js
[00:12]2018DOTA2亚洲邀请赛 Sccc亮相SOLO赛,今年他又会有什么样的战绩?
2018/04/06 DOTA
[01:38]2018DOTA2亚洲邀请赛主赛事第二日现场采访 神秘商人痛陈生计不易
2018/04/05 DOTA
在Python中操作字符串之startswith()方法的使用
2015/05/20 Python
PyQt 实现使窗口中的元素跟随窗口大小的变化而变化
2019/06/18 Python
python调用其他文件函数或类的示例
2019/07/16 Python
MyFrenchPharma中文网:最大的法国药妆平台
2016/10/07 全球购物
技校生自我鉴定
2013/12/08 职场文书
社区班子个人对照检查材料思想汇报
2014/10/07 职场文书
乡镇党的群众路线教育实践活动剖析材料
2014/10/09 职场文书
2014年档案管理工作总结
2014/11/17 职场文书
事业单位考察材料范文
2014/12/25 职场文书
专业技术职务聘任证明
2015/03/02 职场文书
2015年推普周活动总结
2015/03/27 职场文书
重阳节活动主持词
2015/07/04 职场文书
python实现监听键盘
2021/04/26 Python