JSON.parse和JSON.stringify的巧用

更新日期: 2019-12-07阅读: 1.7k标签: json

JSON.parse和JSON.stringify是对json数据的转换,在js中使用的频率还是非常高的,比如localStorage,cookie中对复合型数据的存储,与服务器进行数据交互的格式转换等等。

JSON.stringify()是将一个JavaScript值(对象或者数组)转换为一个json字符串,如果指定了 replacer 是一个函数,则可以选择性地替换值,或者如果指定了 replacer 是一个数组,则可选择性地仅包含数组指定的属性。

语法

JSON.stringify(value[, replacer [, space]])

value:要进行转换的JSON对象;
replacer|可选:如果该参数是一个函数,则在序列化过程中,被序列化的值的每个属性都会经过该函数的转换和处理;如果该参数是一个数组,则只有包含在这个数组中的属性名才会被序列化到最终的 JSON 字符串中;如果该参数为 null 或者未提供,则对象所有的属性都会被序列化;
space|可选:指定缩进用的空白字符串,用于美化输出

注意:
1、转换值如果有 toJSON() 方法,该方法定义什么值将被序列化
2、非数组对象的属性不能保证以特定的顺序出现在序列化后的字符串中。
3、布尔值、数字、字符串的包装对象在序列化过程中会自动转换成对应的原始值。
4、undefined、任意的函数以及 symbol 值,在序列化过程中会被忽略(出现在非数组对象的属性值中时)或者被转换成null(出现在数组中时)。函数、undefined 被单独转换时,会返回 undefined。
5、对包含循环引用的对象(对象之间相互引用,形成无限循环)执行此方法,会抛出错误。
6、以 symbol 为属性键的属性都会被完全忽略掉,即便replacer参数中强制指定包含了它们
7、Date 日期调用了 toJSON() 将其转换为了 string 字符串(同Date.toISOString()),因此会被当做字符串处理。
8、NaN 和 Infinity 格式的数值及 null 都会被当做 null。
JSON.stringify({});                        // '{}'
JSON.stringify(true);                      // 'true'
JSON.stringify("foo");                     // '"foo"'
JSON.stringify([1, "false", false]);       // '[1,"false",false]'
JSON.stringify({ x: 5 });                  // '{"x":5}'

JSON.stringify([undefined, Object, Symbol("")]);          
// '[null,null,null]'

replacer参数
replacer 参数可以是一个函数或者一个数组。作为函数,它有两个参数,键(key)和值(value),它们都会被序列化。

const user = { id: 229, name: "John", email: "john@awesome.com" };
 function replacer(key, value) {
      console.log(typeof value);
      if (key === "email") {
        return undefined;
      }
      return value;
}
 const userStr = JSON.stringify(user, replacer); // "{"id":229,"name":"John"}"
JSON.parse()用来解析JSON字符串,构造由字符串描述的JavaScript值或对象。提供可选的reviver函数用以在返回之前对所得到的对象执行变换

语法:

JSON.parse(text\[, reviver\])

text:要被转换的JSON字符串;
reviver|可选:转换器, 如果传入该参数(函数),可以用来修改解析生成的原始值,调用时机在 parse 函数返回之前。

const user = {
    name: "John",
    email: "john@awesome.com",
    plan: "Pro"
};

const userStr = JSON.stringify(user);
JSON.parse(userStr, (key, value) => {
    if (typeof value === "string") {
          return value.toUpperCase();
    }
  return value;
});


技巧

1、判断两个引用数据类型是否相等

var arr1=[1,2];
var arr2=[1,2];
console.log(arr1===arr2);//false
console.log(JSON.stringify(arr1)===JSON.stringify(arr2));//true

2、实现引用类型数据深拷贝

var arr1=[1,2];
var arr2=arr1;
arr2[1]=0;
console.log(arr1);//[1,0]

正常情况下拷贝数组会互相影响,使用JSON.stringify()后

var arr1=[1,2];
var arr3=JSON.stringify(arr1);
arr3=JSON.parse(arr3);
arr3[1]=0;
console.log(arr1);//[1,2]

3、引用类型数据存储

var account={
  uid:123,
  name:"jack"
};
window.localStorage.setItem("account",JSON.stringify(account));

4、debug处理
有时候在客户端内无法打印oject数据查看异常,无法定位问题,比如:

var account={
  uid:123,
  name:"jack"
};
alert(account);//[object,object]
alert(JSON.stringify(account));//{"uid":123,"name":"jack"}

链接: https://www.fly63.com/article/detial/7189

web数据格式中关于:XML/HTML/JSON学习总汇

这篇文章讲解关于XML/HTML/JSON的学习,大家都知道服务器端可以返回的数据格式,主要就是:XML、HTML、JSON,当我们做数据抓取,ajax请求的时候都需要熟悉它们的使用。

解决IE8下JSON.stringify()自动将中文转译成unicode的方法

在IE8下JSON.stringify()自动将中文转译为unicode编码,原本选择的中文字符,传到后台变为了unicode编码,即u****的形式。查找资料后发现,与标准的JSON.stringify()不同,IE8内置的JSON.stringify()会自动将编码从utf-8转为unicode编码,导致出现这种类似于乱码的情况。

js实现json格式化,以及json校验工具的简单实现

这篇文章主要讲解:json结构及形式、json字符串转化为json对象【通过eval( ) 方法,new Function形式,使用全局的JSON对象】、json校验格式化工具简单实现

解析Json字符串的三种方法

在很多时候,我们的需要将类似 json 格式的字符串数据转为json,下面将介绍日常中使用的三种解析json字符串的方法

解决IE8以下低版本实现JSON.parse()与JSON.stringify()的兼容

将字符串和json对象的相互转换,我们通常使用JSON.parse()与JSON.stringify()。解决IE8以下低版本实现JSON.parse()与JSON.stringify()的兼容呢:利用eval方式解析、new Function形式、自定义兼容json的方法、head头添加mate等

什么是数据交互格式?xml和json优缺点

就是客户端和服务端进行信息传输的格式(xml和json),双方约定用什么格式进行传输,然后解析得到自己想要的值,xml扩展标记语言,属于重量级(第一占宽带、第二解析难),json属于轻量级的数据交互格式(不占宽带,解析很简单)

js 将json字符串转换为json对象的方法解析

将json字符串转换为json对象的方法。在数据传输过程中,json是以文本,即字符串的形式传递的,而JS操作的是JSON对象,所以,JSON对象和JSON字符串之间的相互转换是关键

聊聊JSON Schema

json现在已经成为比较通用灵活的数据交换格式,尤其是在web方面,总是少不了它的身影,js原生就支持它。网页中与服务器中和服务器交换信息也基本上式基于json的。在现在的开发中,特别是在前后端分离的开发中,后端提供接口,前端通过接口拿取数据;

百度JSON LD结构化数据代码分享

百度JSON LD结构化数据代码分享,搞外贸网站,企业网站这么就,对谷歌的 schema 结构化数据比较熟悉,但是对百度的结构化数据就了解太少了

什么是JWT(JSON WEB TOKEN)

Json web token(JWT)是为了网络应用环境间传递声明而执行的一种基于JSON的开发标准(RFC 7519),该token被设计为紧凑且安全的,特别适用于分布式站点的单点登陆(SSO)场景。JWT的声明一般被用来在身份提供者和服务提供者间传递被认证的用户身份信息

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!