Jquery中文網 www.uhadif.co
Jquery中文網 >  腳本編程  >  javascript  >  正文 json為什么像花兒一樣紅

json為什么像花兒一樣紅

發布時間:2014-08-15   編輯:www.uhadif.co
json是近年迅速紅遍全球的東東;json.org是一種簡潔有效的數據載體,是一種用字符串表示復雜js對象的方式,后端好生成,前端0解釋。

一看標題就知道是某某黨了,哈哈,不過json的紅火,相信你是有所耳聞的吧。

json是近年迅速紅遍全球的東東;json.org是一種簡潔有效的數據載體,是一種用字符串表示復雜js對象的方式,后端好生成,前端0解釋。

現在解釋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看看吧。

您可能感興趣的文章:
json為什么像花兒一樣紅
javascript實現Json查詢的方法舉例
當jQuery遭遇CoffeeScript的時候 使用分享
php花括號常用規則詳解
$.ajax返回的JSON無法執行success的解決方法
用示例說明filter()與find()的用法以及children()與find()的區別分析
php跨域調用json的例子
jQuery篩選器children()案例詳解(圖文)
Jquery ajax不能解析json對象,報Invalid JSON錯誤的原因和解決方法
jqeury eval將字符串轉換json的方法

[關閉]
北京pk赛车历史 推荐十种网络赚钱方式 广东26选5开奖查询 分级基金都有哪些 汇顶科技股票股吧 选上海快三有什么技巧吗 苹果股票 股票配资平台哪个好多少钱 20选5预测专家 北京赛车app苹果下载 2013年福彩3的319期天中图库好运彩 爱彩乐彩票网 福建快3开奖结果昨天 新疆11选5开奖视频 盈富配资 北京快3官方手机版 幸运农场开奖号码查询