js字符串轉(zhuǎn)json對象的四種實現(xiàn)方法
1. javascript函數(shù)eval()
語法:
var obj = eval ("(" + txt + ")"); //必須把文本包圍在括號中,這樣才能避免語法錯誤
eval()定義:eval() 函數(shù)可計算某個字符串,并執(zhí)行其中的的 JavaScript 代碼。
由于 JSON 語法是 JavaScript 語法的子集,JavaScript 函數(shù) eval() 可用于將 JSON 文本轉(zhuǎn)換為 JavaScript 對象。
注意:當字符串中包含表達式時,eval() 函數(shù)也會編譯并執(zhí)行,轉(zhuǎn)換會存在安全問題。
2. 瀏覽器自帶對象JSON,JSON.parse()
語法:
var obj = JSON.parse(text[, reviver]) //text:必需, 一個有效的 JSON 字符串。解析前要確保你的數(shù)據(jù)是標準的 JSON 格式,否則會解析出錯。 //reviver: 可選,一個轉(zhuǎn)換結(jié)果的函數(shù), 將為對象的每個成員調(diào)用此函數(shù)。
JSON.parse()比eval()安全,而且速度更快。支持主流瀏覽器:Firefox 3.5,IE 8,Chrome,Opera 10,Safari 4。
注意:IE8兼容模式,IE 7,IE 6,會存在兼容性問題。
3. jQuery插件,$.parseJSON()
語法:
var obj = $.parseJSON(json) //json:String類型,傳入格式有誤的JSON字符串可能導致拋出異常
4. ajax請求獲取json數(shù)據(jù)時,$.getJSON()
語法:
jQuery.getJSON(url,data,success(data,status,xhr)) //url 必需。規(guī)定將請求發(fā)送的哪個 URL。 //data 可選。規(guī)定連同請求發(fā)送到服務(wù)器的數(shù)據(jù)。 //success(data,status,xhr) 可選。規(guī)定當請求成功時運行的函數(shù)。
這個時候返回的data已經(jīng)是JSON對象,不需要再進行轉(zhuǎn)換。
$.getJSON() 是簡寫的 Ajax 函數(shù),等價于:
$.ajax({ url: url, data: data, success: callback, dataType: "json" });
總結(jié)
到此這篇關(guān)于js字符串轉(zhuǎn)json對象的四種實現(xiàn)方法的文章就介紹到這了,更多相關(guān)js字符串轉(zhuǎn)json對象內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JavaScript中的幾個關(guān)鍵概念的理解-原型鏈的構(gòu)建
JavaScript中的prototype,標準翻譯為“原型”,表示對象的初始形態(tài)2011-05-05webpack-url-loader 解決項目中圖片打包路徑問題
這篇文章主要介紹了webpack-url-loader 解決項目中圖片打包路徑問題,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-02-02使用Bootstrap typeahead插件實現(xiàn)搜索框自動補全的方法
這篇文章主要介紹了使用Bootstrap typeahead插件實現(xiàn)搜索框自動補全的方法的相關(guān)資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2016-07-07