首頁 >web前端 >js教程 >JSON為什麼那麼紅為什麼要用json(另有洞天)_基礎知識

JSON為什麼那麼紅為什麼要用json(另有洞天)_基礎知識

WBOY
WBOY原創
2016-05-16 17:45:211077瀏覽

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 = '

lenel
';
然後前台接受資料時使用
複製程式碼 程式碼如下:

function toDivElememnt(s){
var oDiv = Element.create" );
oDiv.innerHTML = s;
oDiv = oDiv.firstChild;
return oDiv;
}

這個方法裡面我沒有用js來解釋而是用DOM來解釋HTML串,這也是相當自然的,前面已經說過HTML串也是樹狀結構,我拿到oDiv之後就可以訪問到age,personid等等屬性了,效率也是相當可以的,呵呵。
這不是我的原創啊,來自與我從前的Leader,牛人啊,良師益友。

JSON會取代XML麼?
不會,在Ajax這個領域可能我們會搞Ajaj,但是XML如果只能做這點事那就不是XML了:)

還沒用JSON麼?
不要落伍了哈哈,當前主流的後台語言都有在後台產生、解析JSON的API,具體怎麼用json,API去哪兒找http://www.json.org看看吧

我們真的得到什麼啟示麼?
我還是沒總結出來具體的,但是我認為語言是相通的,javaScript不能IOC麼?
陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn