jQuery.parseJSON()函數(shù)詳解
jQuery.parseJSON()函數(shù)用于將格式完好的JSON字符串轉為與之對應的JavaScript對象。
所謂”格式完好”,就是要求指定的字符串必須符合嚴格的JSON格式,例如:屬性名稱必須加雙引號、字符串值也必須用雙引號。
如果傳入一個格式不”完好”的JSON字符串將拋出一個JS異常,例如:以下字符串均符合JSON格式,但它們不是格式完好的JSON字符串(因此會拋出異常):
// 以下均是字符串值,省略了兩側的引號,以便于展現(xiàn)內容
{id: 1} // id是屬性名稱,必須加雙引號
{'id': 1} // id是屬性名稱,必須用雙引號(不能用單引號)
{"name": 'CodePlayer'} // name屬性的值是字符串,必須用雙引號(不能用單引號)
JSON標準不允許字符串中出現(xiàn)”控制字符”,例如:一個Tab或換行符。
$.parseJSON('{"name": "Code\tPlayer\n"}'); // 多數(shù)情況下,它會拋出一個錯誤,因為JS解析器會將字符串中的\t或\n等轉義直接視作字面值,起到Tab或換行的效果。
//正確寫法應該如下(使用兩個反斜杠,以免被JS解析器直接轉義\t或\n):
$.parseJSON('{"name": "Code\\tPlayer\\n"}');
如果瀏覽器提供了一個本地的JSON.parse()方法,則jQuery將使用它來解析JSON字符串。
在jQuery 1.9之前(不含1.9):如果傳入一個空字符串、null或undefined,該函數(shù)將返回null,而不是拋出一個錯誤,即使它不是有效的JSON字符串。
該函數(shù)屬于全局的jQuery對象。
語法
jQuery 1.4.1 新增該靜態(tài)函數(shù)。
jQuery.parseJSON( jsonString ) 參數(shù)
參數(shù) 描述 jsonString String類型需要解析并轉為JS對象的JSON格式字符串。 返回值
jQuery.parseJSON()函數(shù)的返回值為任意類型,返回解析指定JSON字符串后的JavaScript表示。
示例&說明
以下是與jQuery.parseJSON()函數(shù)相關的jQuery示例代碼,以演示jQuery.parseJSON()函數(shù)的具體用法:
var result1 = $.parseJSON( "{}" ); // 一個空的Object對象
var result2 = $.parseJSON( '{ "name": "CodePlayer", "age": 1 }' ); // 一個Object對象
alert( result2.name ); // CodePlayer
var result3 = $.parseJSON( '[ 1, true, "CodePlayer" ]' ); // 一個Object對象
alert( result3[2] ); // CodePlayer
var result4 = $.parseJSON( 'true' ); // 布爾值:true
var result5 = $.parseJSON( 'null' ); // null
var result6 = $.parseJSON( '0' ); // 整數(shù):0
var result7 = $.parseJSON( '"專注于編程開發(fā)技術分享"' ); // 字符串值:專注于編程開發(fā)技術分享
var result8 = $.parseJSON( "\"專注于編程開發(fā)技術分享\"" ); // 字符串值:專注于編程開發(fā)技術分享
/* 以下均是無效的JSON字符串或非常規(guī)的參數(shù)值 */
var result9 = $.parseJSON( 100 ); // 1.9之前返回null;1.9+返回100
var result10 = $.parseJSON( 1.23 ); // 1.9之前返回null;1.9+返回1.23
var result11 = $.parseJSON( true ); // 1.9之前返回null;1.9+返回true
var result12 = $.parseJSON( null ); // 返回null
var result13 = $.parseJSON( "" ); // 1.9之前返回null;1.9+拋出錯誤
var result14 = $.parseJSON( undefined ); // 1.9之前返回null;1.9+拋出錯誤
var result15 = $.parseJSON( "undefined" ); // 拋出錯誤
var result16 = $.parseJSON( "12x;xx'無效的JSON字符串x4546" ); // 拋出錯誤
var result17 = $.parseJSON( '{ name: "CodePlayer", age: 1 }' ); // 拋出錯誤
var result18 = $.parseJSON( '{ "name": \'CodePlayer\', "age": 1 }' ); // 拋出錯誤
var result19 = $.parseJSON( '{ "name": "Code\tPlayer\n" }' ); // 拋出錯誤
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。如果你想了解更多相關內容請查看下面相關鏈接
- 詳解jQuery-each()方法
- 使用jquery的cookie實現(xiàn)登錄頁記住用戶名和密碼的方法
- Jquery的autocomplete插件用法及參數(shù)講解
- JS/jQuery實現(xiàn)獲取時間的方法及常用類完整示例
- PHP結合jquery ajax實現(xiàn)上傳多張圖片,并限制圖片大小操作示例
- jQuery each和js forEach用法比較
- 原生JS forEach()和map()遍歷的區(qū)別、兼容寫法及jQuery $.each、$.map遍歷操作
- PHP+jQuery實現(xiàn)雙擊修改table表格功能示例
- PHP+jQuery實現(xiàn)即點即改功能示例
- 簡單易擴展可控性強的Jquery轉盤抽獎程序
相關文章
使用jQuery全局事件ajaxStart為特定請求實現(xiàn)提示效果的代碼
首先,重寫Ajax方法的代價太高,仍然可以利用jQuery自身的Ajax Events。2010-12-12
jQuery基于函數(shù)重載實現(xiàn)自定義Alert函數(shù)樣式的方法
這篇文章主要介紹了jQuery基于函數(shù)重載實現(xiàn)自定義Alert函數(shù)樣式的方法,涉及jQuery函數(shù)重載及頁面元素屬性動態(tài)操作的相關技巧,需要的朋友可以參考下2016-07-07
jQuery實現(xiàn)的粘性滾動導航欄效果實例【附源碼下載】
這篇文章主要介紹了jQuery實現(xiàn)的粘性滾動導航欄效果,涉及jQuery插件smint的相關使用技巧,并附帶完整實例源碼供讀者下載參考,需要的朋友可以參考下2017-10-10
jquery $.ajax()取xml數(shù)據(jù)的小問題解決方法
今天想做一個用$.ajax()從xml中讀取數(shù)據(jù)的這么一個異步交互過程2010-11-11
基于jquery的彈出提示框始終處于窗口的居中位置(類似于alert彈出框的效果)
之前寫的代碼,都是在當前窗口位于居中,可是一旦窗口縮小或者放大都不是位于居中的位置了,但是一直想寫的一個類似于alert彈出窗口的效果。2011-09-09

