Json字符串轉(zhuǎn)換為JS對(duì)象的高效方法實(shí)例
今天學(xué)習(xí)JQuery源碼看到一下方法,原來還可以這樣解析JSON字符串:
parseJSON: function( data ) {
if ( typeof data !== "string" || !data ) {
return null;
}
// Make sure leading/trailing whitespace is removed (IE can't handle it)
data = jQuery.trim( data );
// Make sure the incoming data is actual JSON
// Logic borrowed from http://json.org/json2.js
if ( /^[/],:{}/s]*$/.test(data.replace(///(?:["http:////bfnrt]|u[0-9a-fA-F]{4})/g, "@")
.replace(/"[^"http:///n/r]*"|true|false|null|-?/d+(?:/./d*)?(?:[eE][+/-]?/d+)?/g, "]")
.replace(/(?:^|:|,)(?:/s*/[)+/g, "")) ) {
// Try to use the native JSON parser first
return window.JSON && window.JSON.parse ?
window.JSON.parse( data ) :
(new Function("return " + data))();
} else {
jQuery.error( "Invalid JSON: " + data );
}
}
這個(gè)方法核心的代碼就是:
(new Function("return " + data))();
它使用了Function()構(gòu)造函數(shù)。講json字符串作為函數(shù)執(zhí)行數(shù)據(jù)傳入,定義后立即執(zhí)行該函數(shù),此時(shí)這個(gè)函數(shù)會(huì)返回JSON對(duì)象
我做了一個(gè)測(cè)試,用這個(gè)方法解析JSON字符串的效率要比用Eval解析快好幾百倍
var jsonStr ="{";
for(var i=0;i<10000;i++){
jsonStr+="a"+i+":"+i+","
}
jsonStr = jsonStr.substring(0,jsonStr.length-1);
jsonStr+="}";
var date = new Date();
var start = date.getTime()
//var boj = (new Function("return "+jsonStr ))();
var boj = eval("("+jsonStr+")");
var date1 = new Date();
console.info(date1.getTime()-start);
我用firfox測(cè)試結(jié)果,用eval解析花費(fèi)了7234毫秒,而用函數(shù)這種方法,用了55毫秒,太神奇了.
- JS對(duì)象與json字符串格式轉(zhuǎn)換實(shí)例
- jQuery.parseJSON(json)將JSON字符串轉(zhuǎn)換成js對(duì)象
- Json對(duì)象與Json字符串互轉(zhuǎn)(4種轉(zhuǎn)換方式)
- js 將json字符串轉(zhuǎn)換為json對(duì)象的方法解析
- js中把JSON字符串轉(zhuǎn)換成JSON對(duì)象最好的方法
- 將JSON字符串轉(zhuǎn)換成Map對(duì)象的方法
- Java中Json字符串直接轉(zhuǎn)換為對(duì)象的方法(包括多層List集合)
- JSON字符串和對(duì)象之間的轉(zhuǎn)換詳解
- JS對(duì)象與json字符串相互轉(zhuǎn)換實(shí)現(xiàn)方法示例
相關(guān)文章
JS中如何將JSON數(shù)組轉(zhuǎn)化為url參數(shù)
這篇文章主要介紹了JS中如何將JSON數(shù)組轉(zhuǎn)化為url參數(shù)問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-04-04javascript獲取下拉列表框當(dāng)中的文本值示例代碼
需要將用戶點(diǎn)擊下拉列表當(dāng)中某個(gè)選項(xiàng)后,將其所選的內(nèi)容保存起來,下面與大家分享下如何使用js獲取下拉列表框文本值,由此需求的朋友可以參考下2013-07-07關(guān)于JavaScript遞歸經(jīng)典案例題詳析
遞歸是算法中一個(gè)重要的解法,因此,有必要單拎出來講講,所以下面這篇文章主要給大家介紹了關(guān)于JavaScript遞歸經(jīng)典案例題的相關(guān)資料,需要的朋友可以參考下2021-07-07JavaScript表單通過正則表達(dá)式驗(yàn)證電話號(hào)碼
通過正則表達(dá)式實(shí)現(xiàn)判斷一個(gè)輸入量是否為電話號(hào)碼,需要的朋友可以參考下2014-03-03js驗(yàn)證輸入是否為手機(jī)號(hào)碼或電話號(hào)碼示例
使用js驗(yàn)證輸入是否為手機(jī)號(hào)碼或電話號(hào)碼,下面有個(gè)不錯(cuò)的示例,感興趣的朋友可以參考下2013-12-12獲取客戶端網(wǎng)卡MAC地址和IP地址實(shí)現(xiàn)JS代碼
獲取客戶端的一些信息,如IP和MAC,以結(jié)合身份驗(yàn)證,相信很多人都會(huì)這樣做吧,我們這里用Javascript,這樣做的好處是不需要服務(wù)器端進(jìn)行處理,有客戶端自行獲取,感興趣的你可以參考下哈2013-03-03