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

10年服务1亿Tian开发工程师

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

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

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

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

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

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

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

上面的转换可以这么写:

var a={"name":"tom","sex":"男","age":"24"};

var b='{"name":"Mike","sex":"女","age":"29"}';

var aToStr=JSON.stringify(a);

var bToObj=JSON.parse(b);

console.log(typeof(aToStr)); ?//string

console.log(typeof(bToObj));//object

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

const myArr = ['bacon', 'letuce', 'tomatoes'];

const myArrStr = JSON.stringify(myArr);

console.log(myArrStr);
// "["bacon","letuce","tomatoes"]"

console.log(JSON.parse(myArrStr));
// ["bacon","letuce","tomatoes"]

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

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

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

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

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

相关推荐

1.JavaScript如何解析json

2.javascript如何将JSON对象转为map对象

3.json答疑

赞(0) 打赏
未经允许不得转载:WEBTian开发 » JSON对象和字符串之间的相互转换 – JSON.parse() 和 JSON.stringify()

评论 11

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址
  1. #-49

    看了下你 $(“#loading2 div”).animate({width:”100%”}, function() {
    setTimeout(function() {
    $(“#loading2”).hide();
    }, 1000);
    });
    这个进度条其实是假冒的 载入进度条嘛!

    8年前 (2011-07-30)回复
  2. #-48

    日期对象好像不能互转???求解!!!

    njl7年前 (2011-09-06)回复
  3. #-47

    3年前 (2015-08-25)回复
  4. #-46


    可以结合这篇文章一起学习!

    8个月前 (05-17)回复
    • 谢谢!!!非常感谢!!!

      7个月前 (06-17)回复

Tian开发相关广告投放 更专业 更精准

联系我们

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

微信扫一扫打赏