JSON 入門(mén)教程基礎(chǔ)篇 json入門(mén)學(xué)習(xí)筆記
JSON: JavaScript Object Notation(JavaScript 對(duì)象表示法)
JSON 是存儲(chǔ)和交換文本信息的語(yǔ)法。類(lèi)似 XML。
JSON 比 XML 更小、更快,更易解析。
JSON 實(shí)例
{ "sites": [ { "name":"腳本之家" , "url":"www.dbjr.com.cn" }, { "name":"google" , "url":"www.google.com" }, { "name":"微博" , "url":"www.weibo.com" } ] }
這個(gè) sites 對(duì)象是包含 3 個(gè)站點(diǎn)記錄(對(duì)象)的數(shù)組。
什么是 JSON ?
JSON 指的是 JavaScript 對(duì)象表示法(JavaScript Object Notation)
JSON 是輕量級(jí)的文本數(shù)據(jù)交換格式
JSON 獨(dú)立于語(yǔ)言:JSON 使用 Javascript語(yǔ)法來(lái)描述數(shù)據(jù)對(duì)象,但是 JSON 仍然獨(dú)立于語(yǔ)言和平臺(tái)。JSON 解析器和 JSON 庫(kù)支持許多不同的編程語(yǔ)言。 目前非常多的動(dòng)態(tài)(PHP,JSP,.NET)編程語(yǔ)言都支持JSON。
JSON 具有自我描述性,更易理解
JSON - 轉(zhuǎn)換為 JavaScript 對(duì)象
JSON 文本格式在語(yǔ)法上與創(chuàng)建 JavaScript 對(duì)象的代碼相同。
由于這種相似性,無(wú)需解析器,JavaScript 程序能夠使用內(nèi)建的 eval() 函數(shù),用 JSON 數(shù)據(jù)來(lái)生成原生的 JavaScript 對(duì)象。
在線實(shí)例
通過(guò)我們的編輯器,您可以在線編輯 JavaScript 代碼,然后通過(guò)點(diǎn)擊一個(gè)按鈕來(lái)查看結(jié)果:
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>腳本之家(jb51.net)</title> </head> <body> <h2>JavaScript 創(chuàng)建 JSON 對(duì)象</h2> <p> 網(wǎng)站名稱(chēng): <span id="jname"></span><br /> 網(wǎng)站地址: <span id="jurl"></span><br /> 網(wǎng)站 slogan: <span id="jslogan"></span><br /> </p> <script> var JSONObject= { "name":"腳本之家", "url":"www.dbjr.com.cn", "slogan":"學(xué)的不僅是技術(shù),更是夢(mèng)想!" }; document.getElementById("jname").innerHTML=JSONObject.name document.getElementById("jurl").innerHTML=JSONObject.url document.getElementById("jslogan").innerHTML=JSONObject.slogan </script> </body> </html>
與 XML 相同之處
JSON 是純文本
JSON 具有"自我描述性"(人類(lèi)可讀)
JSON 具有層級(jí)結(jié)構(gòu)(值中存在值)
JSON 可通過(guò) JavaScript 進(jìn)行解析
JSON 數(shù)據(jù)可使用 AJAX 進(jìn)行傳輸
與 XML 不同之處
沒(méi)有結(jié)束標(biāo)簽
更短
讀寫(xiě)的速度更快
能夠使用內(nèi)建的 JavaScript eval() 方法進(jìn)行解析
使用數(shù)組
不使用保留字
為什么使用 JSON?
對(duì)于 AJAX 應(yīng)用程序來(lái)說(shuō),JSON 比 XML 更快更易使用:
使用 XML
讀取 XML 文檔
使用 XML DOM 來(lái)循環(huán)遍歷文檔
讀取值并存儲(chǔ)在變量中
使用 JSON
讀取 JSON 字符串
用 eval() 處理 JSON 字符串
JSON 語(yǔ)法
JSON 語(yǔ)法是 JavaScript 語(yǔ)法的子集。
JSON 語(yǔ)法規(guī)則
JSON 語(yǔ)法是 JavaScript 對(duì)象表示語(yǔ)法的子集。
數(shù)據(jù)在名稱(chēng)/值對(duì)中
數(shù)據(jù)由逗號(hào)分隔
大括號(hào)保存對(duì)象
中括號(hào)保存數(shù)組
JSON 名稱(chēng)/值對(duì)
JSON 數(shù)據(jù)的書(shū)寫(xiě)格式是:名稱(chēng)/值對(duì)。
名稱(chēng)/值對(duì)包括字段名稱(chēng)(在雙引號(hào)中),后面寫(xiě)一個(gè)冒號(hào),然后是值:
"name" : "腳本之家"
這很容易理解,等價(jià)于這條 JavaScript 語(yǔ)句:
name = "腳本之家"
JSON 值
JSON 值可以是:
數(shù)字(整數(shù)或浮點(diǎn)數(shù))
字符串(在雙引號(hào)中)
邏輯值(true 或 false)
數(shù)組(在中括號(hào)中)
對(duì)象(在大括號(hào)中)
null
JSON 數(shù)字
JSON 數(shù)字可以是整型或者浮點(diǎn)型:
{ "age":30 }
JSON 對(duì)象
JSON 對(duì)象在大括號(hào)({})中書(shū)寫(xiě):
對(duì)象可以包含多個(gè)名稱(chēng)/值對(duì):
{ "name":"腳本之家" , "url":"www.dbjr.com.cn" }
這一點(diǎn)也容易理解,與這條 JavaScript 語(yǔ)句等價(jià):
name = "腳本之家"
url = "www.dbjr.com.cn"
JSON 數(shù)組
JSON 數(shù)組在中括號(hào)中書(shū)寫(xiě):
數(shù)組可包含多個(gè)對(duì)象:
{
"sites": [
{ "name":"腳本之家" , "url":"www.dbjr.com.cn" },
{ "name":"google" , "url":"www.google.com" },
{ "name":"微博" , "url":"www.weibo.com" }
]
}
在上面的例子中,對(duì)象 "sites" 是包含三個(gè)對(duì)象的數(shù)組。每個(gè)對(duì)象代表一條關(guān)于某個(gè)網(wǎng)站(name、url)的記錄。
JSON 布爾值
JSON 布爾值可以是 true 或者 false:
{ "flag":true }
JSON null
JSON 可以設(shè)置 null 值:
{ "jb51":null }
JSON 使用 JavaScript 語(yǔ)法
因?yàn)?JSON 使用 JavaScript 語(yǔ)法,所以無(wú)需額外的軟件就能處理 JavaScript 中的 JSON。
通過(guò) JavaScript,您可以創(chuàng)建一個(gè)對(duì)象數(shù)組,并像這樣進(jìn)行賦值:
var sites = [
{ "name":"jb51" , "url":"www.jb51.com" },
{ "name":"google" , "url":"www.google.com" },
{ "name":"微博" , "url":"www.weibo.com" }
];
可以像這樣訪問(wèn) JavaScript 對(duì)象數(shù)組中的第一項(xiàng)(索引從 0 開(kāi)始):
sites[0].name;
返回的內(nèi)容是:
jb51
可以像這樣修改數(shù)據(jù):
sites[0].name="腳本之家";
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>腳本之家(jb51.com)</title> </head> <body> <h2>JavaScript 創(chuàng)建 JSON 對(duì)象</h2> <p>第一個(gè)網(wǎng)站名稱(chēng): <span id="name1"></span></p> <p>第一個(gè)網(wǎng)站修改后的名稱(chēng): <span id="name2"></span></p> <script> var sites = [ { "name":"jb51" , "url":"www.jb51.com" }, { "name":"google" , "url":"www.google.com" }, { "name":"微博" , "url":"www.weibo.com" } ]; document.getElementById("name1").innerHTML=sites[0].name; // 修改網(wǎng)站名稱(chēng) sites[0].name="腳本之家"; document.getElementById("name2").innerHTML=sites[0].name; </script> </body> </html>
在下面的章節(jié),您將學(xué)到如何把 JSON 文本轉(zhuǎn)換為 JavaScript 對(duì)象。
JSON 文件
JSON 文件的文件類(lèi)型是 ".json"
JSON 文本的 MIME 類(lèi)型是 "application/json"
JSON vs XML
JSON 和 XML 都用于接收 web 服務(wù)端的數(shù)據(jù)。
JSON 和 XML在寫(xiě)法上有所不同,如下所示:
JSON 實(shí)例
{
"sites": [
{ "name":"腳本之家" , "url":"www.jb51.com" },
{ "name":"google" , "url":"www.google.com" },
{ "name":"微博" , "url":"www.weibo.com" }
]
}
XML 實(shí)例
<sites> <site> <name>腳本之家</name> <url>www.jb51.com</url> </site> <site> <name>google</name> <url>www.google.com</url> </site> <site> <name>微博</name> <url>www.weibo.com</url> </site> </sites>
JSON 與 XML 的相同之處:
JSON 和 XML 數(shù)據(jù)都是 "自我描述" ,都易于理解。
JSON 和 XML 數(shù)據(jù)都是有層次的結(jié)構(gòu)
JSON 和 XML 數(shù)據(jù)可以被大多數(shù)編程語(yǔ)言使用
JSON 與 XML 的不同之處:
JSON 不需要結(jié)束標(biāo)簽
JSON 更加簡(jiǎn)短
JSON 讀寫(xiě)速度更快
JSON 可以使用數(shù)組
最大的不同是:XML 需要使用 XML 解析器來(lái)解析,JSON 可以使用標(biāo)準(zhǔn)的 JavaScript 函數(shù)來(lái)解析。
JSON.parse(): 將一個(gè) JSON 字符串轉(zhuǎn)換為 JavaScript 對(duì)象。
JSON.stringify(): 于將 JavaScript 值轉(zhuǎn)換為 JSON 字符串。
為什么 JSON 比 XML 更好?
XML 比 JSON 更難解析。
JSON 可以直接使用現(xiàn)有的 JavaScript 對(duì)象解析。
針對(duì) AJAX 應(yīng)用,JSON 比 XML 數(shù)據(jù)加載更快,而且更簡(jiǎn)單:
使用 XML
獲取 XML 文檔
使用 XML DOM 迭代循環(huán)文檔
接數(shù)據(jù)解析出來(lái)復(fù)制給變量
使用 JSON
獲取 JSON 字符串
JSON.Parse 解析 JSON 字符串
相關(guān)文章
json的定義、標(biāo)準(zhǔn)格式及json字符串檢驗(yàn)
今天分享和總結(jié)一些json的基本定義、格式、字符串的格式,以及在做測(cè)試的時(shí)候使用json時(shí)做一些簡(jiǎn)單的校驗(yàn)2014-05-05JSON.parse 數(shù)據(jù)不完整的解決方法
本文主要介紹了JSON.parse 數(shù)據(jù)不完整的解決方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-07-07Javascript 通過(guò)json自動(dòng)生成Dom的代碼
主要還是通過(guò)遞歸和迭代來(lái)遍歷json成員生成html元素 ,比較好的是num能制定循環(huán)次數(shù)可以少寫(xiě)很多代碼.具體應(yīng)用看場(chǎng)景了2010-04-04比較詳細(xì)的關(guān)于javascript 解析json的代碼
JSON (JavaScript Object Notation)一種簡(jiǎn)單的數(shù)據(jù)格式,比xml更輕巧。 JSON 是 JavaScript 原生格式,這意味著在 JavaScript 中處理 JSON 數(shù)據(jù)不需要任何特殊的 API 或工具包。2009-12-12javascript表單域與json數(shù)據(jù)間的交互
找了幾個(gè)javascript的框架,都沒(méi)有找到我想要的: 提供函數(shù),把某個(gè)表單的所有域封裝成json數(shù)據(jù)格式的對(duì)象,唯有自己實(shí)現(xiàn)一個(gè)。2008-10-10JQuery用$.ajax或$.getJSON跨域獲取JSON數(shù)據(jù)的實(shí)現(xiàn)代碼
這篇文章主要介紹了JQuery用$.ajax或$.getJSON跨域獲取JSON數(shù)據(jù)的實(shí)現(xiàn)代碼,需要的朋友可以參考下2017-09-09json的前臺(tái)操作和后臺(tái)操作實(shí)現(xiàn)代碼
通常情況下,json的在項(xiàng)目中的應(yīng)用都是在后臺(tái)把數(shù)據(jù)傳到前臺(tái),然后前臺(tái)再獲取json中的數(shù)據(jù).2012-01-01說(shuō)說(shuō)JSON和JSONP 也許你會(huì)豁然開(kāi)朗
說(shuō)到AJAX就會(huì)不可避免的面臨兩個(gè)問(wèn)題,第一個(gè)是AJAX以何種格式來(lái)交換數(shù)據(jù)?第二個(gè)是跨域的需求如何解決2012-09-09web頁(yè)面數(shù)據(jù)展示新想法(json)
若使用json作為客戶(hù)端和服務(wù)器之間的數(shù)據(jù)交換格式,代替原來(lái)的html交換格式。2010-06-06