Ajax是「異步javascript和XML」的縮寫已經衆所周知,然而雖然XML是看上去的重要組成部分,它卻不是必須的。一位資深的軟件工程師Douglas Crock ford 開發了一個內建於 javascript 的數據格式,稱爲javascript 對象表示(JSON,javascript Object Notation),意思是直接使用Ajax對象來傳遞信息,能夠讀做「Jason」。
1. 什麼是 JSON
JSON概念很簡單,JSON 是一種輕量級的數據格式,他基於 javascript 語法的子集,即數組和對象表示。因爲使用的是 javascript 語法,所以JSON 定義能夠包含在javascript 文件中,對其的訪問無需經過基於 XML 的語言來額外解析。不過在使用 JSON 以前,很重要的一點是理解 javascript 中數組及對象字面量的特殊語法。
1.1 數組字面量
數組字面量,是用一對方括號括起一組用逗號隔開的 javascript 值,例如:
var aNames=["hello", 12, true , null];
1.2 對象字面量
對象字面量,是經過兩個花括號來定義的。在花括號內能夠放置任意數量的「名稱-值」對,定義格 式字符串值」。除了最後一行外,每一個「名稱-值」對後必須有一個逗號(這與Perl 中的聯合數組的定義有些相似)。例如:
var oCar = {
"color": "red",
"doors" : 4,
"paidFor" : true
};
1.3 混合字面量
咱們能夠混用對象和數組字面量,來建立一個對象數組,或一個包含數組的對象。例如:
{comments:[
{
id:1,
author:"someone1",
url:"http://someone1.x2design.net
",
content:"hello"
},
{
id:2,
author:"someone2",
url:"http://someone2.x2design.net
",
content:"hello"
},
{
id:3,
author:"someone3",
url:"http://someone3.x2design.net
",
content:"hello"
}
]};
1.4 JSON 語法
在Ajax應用中,就是服務器直接生成javascript語句,客戶端獲取後直接用eval方法來得到這個對象,這樣就能夠省去解析XML的性能損失。同時,在javascript 通訊中使用JSON做爲數據格式的好處很明星,能夠當即得到數據的值,所以能夠更快的訪問其中包含的數據。
var oCarInfo = eval("(" + sJSON + ")");
請記住:在javascript中花括號也是一個語句。要讓解析器知道這個花括號表示的是一個對象而非一個語句的惟一方法是可否找到封裝它的圓括號(它是用來講明代碼是一個表達式而非一個語句)。
1.5 JSON 編碼和解碼
在上面提出用到eval() 存在些固有的不足:它是用來對傳入的任何 Javascript 代碼求值的,而不只僅針對JSON。所以,當涉及企業級 web 應用程序開發時,它存在很大的安全隱患。爲了解決這個問題,可使用只用來將 JSON 代碼轉換爲 Javascript 的解析器 JSON.parse() 方法來實現。例如:
var oObject = JSON.parse (sJSON);
同時,它也提供了一種將 Javascript 對象轉換爲 JSON 字符串(數據傳輸時使用的)的工具(在Javascript 中沒有內建這種功能支持)。你要作的只是將對象傳入到 JSON.Stringify() 方法。請看下面的例子:
var oCar = new Object();
oCar.doors = 4;
oCar.color = "blue";
oCar.year = 1995;
oCar.drivers = new Array("Penny", "Dan" , "Kris");
document.write(JSON.stringify(oCar));
這段代碼將輸出以下所示的JSON 字符串:
{"doors" : 4, "color" : "blue", "year" :1995, "drivers" : ["Penny", "Dan" , "Kris"]}
2. JSON 與 XML
正如上面所說,JSON 與 XML 相比的一大優勢就是它更加簡單。
請看 XML 數據表示實例:
使用XML表示:
<comments>
<comment>
<id>1</id>
<author>someone1</author>
<url>[url]http://someone1.x2design.net</url>[/url]
<content>hello</content>
</comment>
<comment>
<id>2</id>
<author>someone2</author>
<url>[url]http://someone2.x2design.net</url>[/url]
<content>someone1</content>
</comment>
<comment>
<id>3</id>
<author>someone3</author>
<url>[url]http://someone3.x2design.net</url>[/url]
<content>hello</content>
</comment>
</comments>
使用JSON表示:
{comments:[
{
id:1,
author:"someone1",
url:"http://someone1.x2design.net
",
content:"hello"
},
{
id:2,
author:"someone2",
url:"http://someone2.x2design.net
",
content:"hello"
},
{
id:3,
author:"someone3",
url:"http://someone3.x2design.net
",
content:"hello"
}
]};
很容易發現,許多冗餘的信息不見了。因爲不須要有與開始標籤(opening tag)匹配的結束標籤(closing tag),所以傳送相同的信息所需的字節數大大下降了。創始人 Corockford 將其稱之爲「XML 的減肥方案」)。
JSON 格式的數據與 XML 相比,缺點是對於外行人可讀性更差。固然,有一種觀點是,數據交換格式不是用肉眼觀察的。若是是經過工具對來回傳送的數據進行建立和解析,那麼的確沒有理由要求數據必須令人們易於閱讀。問題的實質在於:存在可用的 JSON 工具。
3. 服務器端 JSON 工具
中下載,它能夠在 JSP 中使用。
4. JSON 優點與缺點
JSON不只減小了解析XML解析帶來的性能問題和兼容性問題,並且對於javascript來講很是容易使用,能夠方便的經過遍歷數組以及訪問對象屬性來獲取數據,其可讀性也不錯,基本具有告終構化數據的性質。不得不說是一個很好的辦法,並且事實上google maps就沒有采用XML傳遞數據,而是採用了JSON方案。
JSON 另一個優點是跨域可行性,例如你在
[url]www.xxx.com[/url]
的網頁裏使用是徹底可行的,這就意味着你能夠跨域傳遞信息。而使用XMLHttpRequest卻獲取不了跨域的信息,這是javascript內部的安全性質所限制的。
JSON看上去很美,是否是就能徹底取代XML呢?事實並不是如此,而緣由就在於XML的優點:通用性。要使服務器端產生語法合格的javascript代碼並非很容易作到的,這主要發生在比較龐大的系統,服務器端和客戶端有不一樣的開發人員。它們必須協商對象的格式,這很容易形成錯誤。
不管如何,JSON是一個誘人的技術,準備作一個大量的試用。但願屆時能夠獲取大的性能提升。
參考文獻:
1. Ajax 高級程序設計[M] 圖靈程序設計叢書(Ajax 系列)人民郵電出版社