JSON.parse 与 eval() 对于解析json的问题(
from:https://www.cnblogs.com/zqzjs/p/4693958.html
1.eval()与JSOn.parse的不同
eval()
data:image/s3,"s3://crabby-images/531f1/531f1986f763770be1d86ae8c7087eb756b3c067" alt=""
varc = 1;//全局变量varjsonstr1 = '{"name":"a","company":"b","value":++c}';varjson1 = eval('(' + jsonstr1 + ')');
console.log(json1.value);
data:image/s3,"s3://crabby-images/37284/3728432df9d094031c32c961dced424fb0ef9318" alt=""
data:image/s3,"s3://crabby-images/96f00/96f00cd71dc403ff91ac03b8d2b039b51a5d6159" alt=""
c是全局变量为1,但是经过eval的解析,全局变量变成了2!(这样的写法是危险的)
JSON.parse
data:image/s3,"s3://crabby-images/b18e1/b18e1ab9c1b049574d1b65d1e7c7297ad24eac57" alt=""
varc = 1;//全局变量varjsonstr1 = '{"name":"a","company":"b","value":++c}';varjson2 =JSON.parse(jsonstr1);
console.log(json2.value);
data:image/s3,"s3://crabby-images/54cc7/54cc75c7bf7bace95b090c4bf07d0f7f2fb02a4f" alt=""
IE下报错:
data:image/s3,"s3://crabby-images/66630/66630b406b0692870ca94c18bbb32df780ecbf12" alt=""
谷歌下报错:
data:image/s3,"s3://crabby-images/6b167/6b167e094af9c617894e56346dde102e515bdc99" alt=""
而JSON.parse则会报错。
2.在++c中加上双引号则就可以,因为它变成字符串了。
data:image/s3,"s3://crabby-images/92fc0/92fc055306fd7ac5203c7a6989e85e112c62d6af" alt=""
varc = 1;//全局变量varjsonstr1 = '{"name":"a","company":"b","value":“++c”}';varjson2 =JSON.parse(jsonstr1);
console.log(json2.value);
data:image/s3,"s3://crabby-images/246c8/246c84861bdc5c39e1a24fea6bb7aa51220f3f8e" alt=""
结果:
data:image/s3,"s3://crabby-images/52541/525416c07e1a37e75f2ae7614f9620ddcaace7fc" alt=""
3.我想很多人在纠结双引号的问题,这里我们就来集中测试下。
a:JSON.parse
data:image/s3,"s3://crabby-images/cc501/cc501ab4dc30452bdd0d039b8b82552600b92bb9" alt=""
varc = 1;//全局变量vardate =newDate();
console.log(date.toLocaleDateString());//var jsonstr1 = '{"name":"a","company":"b","value":"++c"}';//键,值都有双引号varjsonstr2 = '{"name":"a","company":"b","value":++c}';//仅++c上午双引号//var jsonstr3 = '{name:"a",company:"b",value:"++c"}';//仅有值上有双引号//var jsonstr4 = '{name:a,company:b,value:++c}';//全无双引号//var json1 = JSON.parse(jsonstr1);varjson2 =JSON.parse(jsonstr2);//var json3 = JSON.parse(jsonstr3);//var json4 = JSON.parse(jsonstr4);//console.log(json1 );console.log(json2 );//console.log(json3);//console.log(json4);
data:image/s3,"s3://crabby-images/1fca6/1fca6294904aa1f0b37be0e2709fba007302ebfe" alt=""
结果依次为:
data:image/s3,"s3://crabby-images/81369/8136930c0ebe9de5c2bfbfd5910af08a86e2d4b2" alt=""
data:image/s3,"s3://crabby-images/8df87/8df87c7d0cbab2c525499e43b0e08e1fec6a49d3" alt=""
data:image/s3,"s3://crabby-images/70050/70050f12f8596c7ce0a9466e50c00fe4496f6887" alt=""
data:image/s3,"s3://crabby-images/c1804/c1804510c6ad66157f997ca448fd4786ae29aa5f" alt=""
可见JSON.parse中只有第一种标准形式才会解析正确
b:eval()
data:image/s3,"s3://crabby-images/5ee74/5ee74a940388ab178831e61a8d886c49ca3534fa" alt=""
varc = 1;//全局变量vardate =newDate();
console.log(date.toLocaleDateString());varjsonstr1 = '{"name":"a","company":"b","value":"++c"}';//键,值都有双引号//var jsonstr2 = '{"name":"a","company":"b","value":++c}';//仅++c上午双引号//var jsonstr3 = '{name:"a",company:"b",value:"++c"}';//仅有值上有双引号//var jsonstr4 = '{name:a,company:b,value:++c}';//全无双引号varjson1 = eval('('+jsonstr1+')');//var json2 = eval('('+jsonstr2+')');//var json3 = eval('('+jsonstr3+')');//var json4 = eval('('+jsonstr4+')');console.log(json1+" "+json1.value );//console.log(json2+" "+json2.value );//console.log(json3 + " " + json3.value);//console.log(json4+" "+json3.value);
data:image/s3,"s3://crabby-images/5864c/5864ce176af0e5b805c6dbdb7306eb1489349e08" alt=""
结果依次为:
data:image/s3,"s3://crabby-images/5a1a4/5a1a47acdc6c0ae16a1124f652f205dd07465aed" alt=""
data:image/s3,"s3://crabby-images/af476/af47619145088fcf9b6f4947b528220eb643cfea" alt=""
data:image/s3,"s3://crabby-images/95110/951105966a43f4607f6fb11182a9f801864b42fc" alt=""
data:image/s3,"s3://crabby-images/37408/374084f0f82cd97aa2ed3274c254e99c62f2f400" alt=""
而eval中除了最后一种,其他都解析正确。
4.这时候还有一个问题:那就是为什么eval()解析的时候要加上括号?
我们先看看不加括号会怎么样:
data:image/s3,"s3://crabby-images/0a4d9/0a4d9995ef671e7b72b97ff94664858fa9dd6e5e" alt=""
varc = 1;//全局变量vardate =newDate();
console.log(date.toLocaleDateString());varjsonstr1 = '{"name":"a","company":"b","value":"++c"}';//键,值都有双引号varjson1 =eval(jsonstr1);
console.log(json1+" "+json1.value );
data:image/s3,"s3://crabby-images/50e27/50e279a1c31135e64c5452997e6ee173db632f95" alt=""
结果:
data:image/s3,"s3://crabby-images/5b478/5b4783080946f68c4b2c500dea4fa10b22dd0a3d" alt=""
这里不加就出错了。
那是因为eval()相当于一个执行环境,当你不加括号的时候,jsonstr1会被认为是一条复合语句。运行的时候就会逐个字符的解析。
但是加上括号的时候,jsonstr1就当做一个表达式去运算。从括号开始就被当做了对象进行识别。
5.然后你又会想到,那这个括号为什么要加“()”,不能加“{}”么?
答案是:当然能加“{}”,只不过就会报错而已~。— —!
这时候你要明吧json的格式是什么!
{"name":"a","company":"b"} 这就是标准形式。