javascript
JSON字符串如何转化成对象?
解析
1、定義:是指將符合 JSON語(yǔ)法規(guī)則的字符串轉(zhuǎn)換成對(duì)象的過(guò)程。
2、不同的編程語(yǔ)言都提供了解析 JSON 字符串的方法,在這里主要講解JavaScript 中的解析方法。主要有三種:
1)-使用 eval()
2)-使用 JSON.parse()
3)-使用第三方庫(kù),例如 JQuery等
eval()
1、eval()函數(shù)的參數(shù)是一個(gè)字符串,其作用是直接執(zhí)行其中的 JavaScript代碼。
2、eval()能夠解析 JSON字符串。從這里也可以看得出,JSON和 JavaScript是高度嵌合的。
3、但是,現(xiàn)在已經(jīng)很少直接使用 eval() 來(lái)解析了,如果您的瀏覽器版本真的是很舊,可能才需要這個(gè)方法。此外,eval()是一個(gè)相對(duì)危險(xiǎn)的函數(shù),因?yàn)樽址锌赡芎形粗蛩亍T谶@里,作為學(xué)習(xí),還是要知道這也是一種方法。
4、請(qǐng)注意 eval()的參數(shù),在字符串兩旁加了括號(hào),這是必須的,否則會(huì)報(bào)錯(cuò)。
5、因?yàn)?JSON字符串是被大括號(hào)(“{}”)包圍的,直接放到eval() 會(huì)被當(dāng)成語(yǔ)句塊來(lái)執(zhí)行,因此要在兩旁加上括號(hào),使其變成表達(dá)式。
示例代碼
<script>
var str = “console.log(‘hello’)”;
eval(sre);
</script>
控制臺(tái)輸出的執(zhí)行結(jié)果:
示例代碼
<script>
var str = ‘{“name”: “Geoff Lui”,“age” ?: 26}’; ??//符合JSON語(yǔ)法規(guī)則的字符串
eval (“(“+str+”)”);
console.log(obj);
</script>
執(zhí)行結(jié)果:
JSON.parse()
1、現(xiàn)在絕大多數(shù)瀏覽器都以支持 JSON.parse(),是推薦使用的方式
示例代碼:
<script>
var str = ‘{“name”: “Geoff Lui”,“age” ?: 26}’; ??//符合JSON語(yǔ)法規(guī)則的字符串
var obj = JSON.parse(str);
console.log(obj);
</script>
?
執(zhí)行結(jié)果:
2、如果輸入了不符合規(guī)范的字符串,會(huì)報(bào)錯(cuò)
3、JSON.parse()可以有第二個(gè)參數(shù),是一個(gè)函數(shù)。此函數(shù)有兩個(gè)參數(shù):name和 value,分別代表名稱和值。當(dāng)傳入一個(gè)JSON 字符串后,JSON的每一組名稱/值對(duì)都要調(diào)用此函數(shù)。該函數(shù)有返回值,返回值將賦值給當(dāng)前的名稱(name)。
示例代碼:
<script>
var str = ‘{“name”: “Geoff Lui”,“age” ?: 26}’; ??//符合JSON語(yǔ)法規(guī)則的字符串
var obj = JSON.parse(str,fun);
function fun (name , value){
console.log(name + “:” + value);
return value;
}
console.log(obj);
</script>
執(zhí)行結(jié)果:
示例代碼:
<script>
var str = ‘{“name”: “Geoff Lui”,“age” ?: 26}’; ??//符合JSON語(yǔ)法規(guī)則的字符串
var obj = JSON.parse(str,fun);
function fun (name , value){
if(name == “age”)
value = 14;
return value;
}
console.log(obj);
</script>
執(zhí)行結(jié)果:
4、利用第二個(gè)參數(shù),可以在解析 JSON字符串的同時(shí)對(duì)數(shù)據(jù)進(jìn)行一些處理。
原文鏈接:http://www.maiziedu.com/wiki/json/conversion/
總結(jié)
以上是生活随笔為你收集整理的JSON字符串如何转化成对象?的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: python复杂网络分析库network
- 下一篇: 在SpringBoot项目中,自定义注解