当前位置:   article > 正文

JSON 数据解析的3种方式_解析json的3种方法

解析json的3种方法

概述

现在JSON格式在web开发中越来越受重视,特别是在使用ajax开发项目的过程中,经常需要将json格式的字符串返回到前端,前端解析成JS对象(JSON )。
ECMA-262(E3)中没有将JSON概念写到标准中,还好在 ECMA-262(E5)中JSON的概念被正式引入了,包括全局的JSON对象和Date的toJSON方法。
解析JSON数据的三种方法的介绍如下:

eval()方法

解析JSON数据的最常用方法是使用javascript的eval()方法,代码如下:

代码如下:

  1. function toJson(str){
  2. var json = eval('(' + str + ')');
  3. return json;
  4. }

该方法存在性能和安全方面的问题,不建议使用。

new Function方法

代码如下:

  1. function toJson(str){
  2. var json = (new Function("return " + str))();
  3. return json;
  4. }

JSON.parse()方法

这种方法只支持IE8/Firefox3.5+/Chrome4/Safari4/Opera10 以上版本,这些浏览器都已经接近W3C标准,默认实现了toJSON方法。

代码如下:

  1. function toJson(str){
  2. return JSON.parse(str);
  3. }

json2.js会在浏览器原生支持JSON.parse的时候选用原生版本,而且它跟ES5是API兼容的。在ES5还没完全普及的现状下,John Resig大神推荐用json2.js主要是为了现在就能用跟ES5兼容的API,日后能平滑过渡到ES5——只要去掉一个import就换过来了。

javascript解析json实例详解

下载json库
http://www.json.org/json-zh.html自己找javascript的
或者直接去下面的
https://github.com/douglascrockford/JSON-js
 
php生成json格式

使用页面 

代码如下:

  1. <script src="scripts/json.js"></script>
  2. alert(data.toJSONString());

如果返回false说明没数据
 

js 代码 

代码如下:

  1. functionshowJSON() {
  2. varuser =
  3. {
  4. "username":"tom",
  5. "age":20,
  6. "info": {"tel":"123456","cellphone":"98765"},
  7. "address":
  8. [
  9. {"city":"shanghai","postcode":"201203"},
  10. {"city":"suzhou","postcode":"200000"}
  11. ]
  12. }
  13. alert(user.username);
  14. alert(user.age);
  15. alert(user.info.cellphone);
  16. alert(user.address[0].city);
  17. alert(user.address[0].postcode);
  18. }

修改 

代码如下:

user.username ="jerry";

可以使用eval来转换JSON字符到Object 

代码如下:

  1. functionmyEval() {
  2. varstr = '{"name":"Violet","occupation":"character"}';
  3. varbj = eval('(' + str + ')');
  4. alert(obj.toJSONString());
  5. }

或者使用parseJSON()方法

代码如下:

  1. functionmyEval() {
  2. varstr = '{"name":"Violet","occupation":"character"}';
  3. varbj = str.parseJSON();
  4. alert(obj.toJSONString());
  5. }
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/Gausst松鼠会/article/detail/351689
推荐阅读
相关标签
  

闽ICP备14008679号