解析Json字串的三種方法

天高任鳥飛吧發表於2018-04-16

在很多時候,我們的需要將類似 json 格式的字串資料轉為json,

下面將介紹日常中使用的三種解析json字串的方法

 1.首先,我們先看一下什麼是 json 格式字串資料,很簡單,就是 json 字串化,在json 最外加單/雙號變為字串資料     

1 var str=`{"name":"Mike","sex":"女","age":"29"}`;
2 var t2="[{name:`lisi`,age:`30`},{name:`wangwu`,age:`16`},{name:`tianqi`,age:`7`}] "

   2.我們用Object.prototype.toString.call() 來檢測資料型別

1 console.log(Object.prototype.toString.call(str));//[object String]
2 console.log(Object.prototype.toString.call(t2));//[object String]

 

第一種方法:evel();

   特點:安全性底,不建議使用,單個JSON物件時要加括號,JSON陣列就不需要了

      示例:

var evajson  =eval(`(`+str+`)`);
var evajsarr = eval(t2);    

  轉換後,再使用Object.prototype.toString.call() 來檢測轉換後的資料型別

1 console.log(Object.prototype.toString.call(evajso))//[object Object]
2 console.log(Object.prototype.toString.call(evajsarr))//[object Array]

 

第二種:new Function()  

 注意:函式要有返回,所以要加“return”;

 示例:

1  var fnjson = new Function("return"+str)();
2  var fnjsonArr = new Function("return"+t2)();

 轉換後,再使用Object.prototype.toString.call() 來檢測轉換後的資料型別

1 console.log(Object.prototype.toString.call(fnjson ))//[object Object]
2 console.log(Object.prototype.toString.call(fnjsonArr ))//[object Array]

 

第二種:JSON.parse() 

特點:主流,相容性好,推薦

 示例:

1  var parjson =  JSON.parse(str);    
2  var parjson =  JSON.parse(t2); 

檢測轉後的資料型別

1  console.log(Object.prototype.toString.call(parjson ))//[object Object]
2  console.log(Object.prototype.toString.call(parjson ))//[object Array]

 

完結,謝謝。。。

參考:https://www.w3cschool.cn/json/8kjw1pl0.html

 

相關文章