在JavaScript中,我們經(jīng)常需要將JSON字符串轉(zhuǎn)換為對(duì)象或從對(duì)象轉(zhuǎn)換為JSON字符串。eval函數(shù)是一種可以實(shí)現(xiàn)字符串轉(zhuǎn)換為JavaScript對(duì)象的方法,但是它在使用中存在著潛在的安全風(fēng)險(xiǎn)。下面我們將探討如何用eval函數(shù)將字符串轉(zhuǎn)換為JSON對(duì)象。
let jsonStr = '{"name": "Tom", "age": 18, "city": "Beijing"}'; let jsonObj = eval('(' + jsonStr + ')'); console.log(jsonObj.name); // "Tom"
上面的代碼將一個(gè)JSON字符串轉(zhuǎn)換為了JavaScript對(duì)象,我們通過(guò)eval將字符串括在圓括號(hào)內(nèi),實(shí)現(xiàn)了將字符串轉(zhuǎn)換為對(duì)象的操作。我們也可以使用JSON.parse方法來(lái)實(shí)現(xiàn)相同的操作,而且它更加安全:
let jsonObj = JSON.parse(jsonStr); console.log(jsonObj.age); // 18
不同于eval函數(shù),JSON.parse只會(huì)解析JSON字符串,不會(huì)執(zhí)行任何額外的JavaScript代碼,從而減少了安全風(fēng)險(xiǎn)。此外,JSON.parse還可以接收一個(gè)可選參數(shù),可以自定義解析過(guò)程中的回調(diào)函數(shù):
let jsonStr = '{"name": "Tom", "age": 18, "city": "Beijing"}'; let reviver = function(key, value) { if (key === 'name') { return 'Jack'; } else { return value; } } let jsonObj = JSON.parse(jsonStr, reviver); console.log(jsonObj.name); // "Jack"
上面的代碼中,我們定義了一個(gè)reviver函數(shù),它會(huì)將JSON對(duì)象中鍵為"name"的值替換為"Jack"。在調(diào)用JSON.parse時(shí),我們將這個(gè)函數(shù)作為參數(shù)傳入,從而讓解析過(guò)程中執(zhí)行這個(gè)回調(diào)函數(shù),實(shí)現(xiàn)了值的替換。