JSON对象和字符串之间的相互转换 – JSON.parse() 和 JSON.stringify()

本文介绍如何使用JSON.parse()和JSON.stringify()方法处理JSON格式的数据,包括将JSON转换为字符串及反之,同时展示了这些方法在现代浏览器中的应用示例。

所有现代浏览器都支持 JSON 对象,有两个非常有用的方法来处理 JSON 格式的内容:

  • JSON.parse(string) :接受一个 JSON 字符串并将其转换成一个 JavaScript 对象。
  • JSON.stringify(obj) :接受一个 JavaScript 对象并将其转换为一个 JSON 字符串。

比如我有两个变量,我要将a转换成字符串,将b转换成JSON对象:

 

js 代码:

  1. var a={"name":"tom","sex":"男","age":"24"};
  2. var b='{"name":"Mike","sex":"女","age":"29"}';

在Firefox,chrome,opera,safari,ie9,ie8等高级浏览器直接可以用JSON对象的stringify()和parse()方法。

JSON.stringify(obj)将JSON转为字符串。

JSON.parse(string)将字符串转为JSON格式;

上面的转换可以这么写:

 

js 代码:

  1. var a={"name":"tom","sex":"男","age":"24"};
  2.  
  3. var b='{"name":"Mike","sex":"女","age":"29"}';
  4.  
  5. var aToStr=JSON.stringify(a);
  6.  
  7. var bToObj=JSON.parse(b);
  8.  
  9. console.log(typeof(aToStr));  //string
  10.  
  11. console.log(typeof(bToObj));//object

尽管这些方法通常用在对象上,但它们也可以在数组上使用:

 

JavaScript 代码:

  1. const myArr = ['bacon', 'letuce', 'tomatoes'];
  2.  
  3. const myArrStr = JSON.stringify(myArr);
  4.  
  5. console.log(myArrStr);
  6. // "["bacon","letuce","tomatoes"]"
  7.  
  8. console.log(JSON.parse(myArrStr));
  9. // ["bacon","letuce","tomatoes"]

ie8(兼容模式),ie7和ie6没有JSON对象,不过http://www.json.org/提供了一个json.js,这样ie8(兼容模式),ie7和ie6就可以支持JSON对象以及其stringify()和parse()方法;你可以在https://github.com/douglascrockford/JSON-js上获取到这个js,一般现在用json2.js。

ie8(兼容模式),ie7和ie6可以使用eval()将字符串转为JSON对象,

 

js 代码:

  1. var c='{"name":"Mike","sex":"女","age":"29"}';
  2. var cToObj=eval("("+c+")");
  3. console.log(typeof(cToObj));

jQuery中也有将字符串转为JSON格式的方法jQuery.parseJSON( json ),接受一个标准格式的 JSON 字符串,并返回解析后的 JavaScript (JSON)对象。当然如果有兴趣可以自己封装一个jQuery扩展,jQuery.stringifyJSON(obj)将JSON转为字符串。

JSON.parse() 和 JSON.stringify() 的高级用法,可以将返回值过滤,转换等。请查看:http://www.css88.com/archives/8735

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值