关于 JavaScript的JSON的一些小技巧

1、格式化

默认的字符串化器还会缩小 JSON,看起来很难看

const user = {name: 'John',age: 30,isAdmin: true,friends: ['Bob', 'Jane'],address: {city: 'New York',country: 'USA'}
};
console.log(JSON.stringify(user));
//=> {"name":"John","age":30,"isAdmin":true,"friends":["Bob","Jane"],"address":{"city":"New York","country":"USA"}}

JSON.stringify也有一个内置的格式化程序!

console.log(JSON.stringify(user, null, 2));
// {
//   "name": "John",
//   "age": 30,
//   "isAdmin": true,
//   "friends": [
//     "Bob",
//     "Jane"
//   ],
//   "address": {
//     "city": "New York",
//     "country": "USA"
//   }
// }

(如果你想知道那个 null 是什么,我们稍后会谈到)

在此示例中,JSON 格式为 2 个缩进空格。

我们还可以指定用于缩进的自定义字符。

console.log(JSON.stringify(user, null, 'lol'));
// {
// lol"name": "John",
// lol"age": 30,
// lol"isAdmin": true,
// lol"friends": [
// lollol"Bob",
// lollol"Jane"
// lol],
// lol"address": {
// lollol"city": "New York",
// lollol"country": "USA"
// lol}
// }

2、隐藏字符串化数据中的某些属性

JSON.stringify第二个参数,这在很大程度上是未知的。它被称为replacer,它是一个函数或数组,用于决定哪些数据保留在输出中,哪些不保留。

这是一个简单的示例,我们可以在其中隐藏password用户。

const user = {name: 'John',password: '12345',age: 30
};console.log(JSON.stringify(user, (key, value) => {if (key === 'password') {return;}return value;
}));

这是输出:
{"name":"John","age":30}
我们可以进一步重构:

function stripKeys(...keys) {return (key, value) => {if (keys.includes(key)) {return;}return value;};
}const user = {name: 'John',password: '12345',age: 30,gender: 'male'
};console.log(JSON.stringify(user, stripKeys('password', 'gender')))

输出:
{"name":"John","age":30}
还可以传递一个数组来仅获取某些键:

const user = {name: 'John',password: '12345',age: 30
}console.log(JSON.stringify(user, ['name', 'age']))

输出相同的东西。

这也适用于数组。如果你有一大堆蛋糕:

const cakes = [{name: 'Chocolate Cake',recipe: ['Mix flour, sugar, cocoa powder, baking powder, eggs, vanilla, and butter','Mix in milk','Bake at 350 degrees for 1 hour',// ...],ingredients: ['flour', 'sugar', 'cocoa powder', 'baking powder', 'eggs', 'vanilla', 'butter']},// tons of these
];

我们可以轻松地做同样的事情,并且替换器将应用于每个蛋糕:

const cakes = [{name: 'Chocolate Cake',recipe: ['Mix flour, sugar, cocoa powder, baking powder, eggs, vanilla, and butter','Mix in milk','Bake at 350 degrees for 1 hour',// ...],ingredients: ['flour', 'sugar', 'cocoa powder', 'baking powder', 'eggs', 'vanilla', 'butter']},// tons of these
];console.log(JSON.stringify(cakes, ['name']))

我们得到这个:
[{"name":"Chocolate Cake"},{"name":"Vanilla Cake"},...]

3、使用toJSON创建自定义输出格式

如果一个对象实现了该toJSON函数,JSON.stringify将使用它来对数据进行字符串化。

考虑一下:

class Fraction {constructor(n, d) {this.numerator = n;this.denominator = d;}
}console.log(JSON.stringify(new Fraction(1, 2)))

这将输出{"numerator":1,"denominator":2}. 但是如果我们想用一个字符串替换它1/2呢?

进入toJSON

class Fraction {constructor(n, d) {this.numerator = n;this.denominator = d;}toJSON() {return `${this.numerator}/${this.denominator}`}
}console.log(JSON.stringify(new Fraction(1, 2)))

JSON.stringify尊重toJSON财产和产出"1/2"。

4、恢复数据

我们上面的分数示例效果很好。但是如果我们想恢复数据呢?当我们再次解析 JSON 时,如果分数能神奇地返回,那不是很酷吗?我们可以!

进入复活者!

class Fraction {constructor(n, d) {this.numerator = n;this.denominator = d;}toJSON() {return `${this.numerator}/${this.denominator}`}static fromJSON(key, value) {if (typeof value === 'string') {const parts = value.split('/').map(Number);if (parts.length === 2) return new Fraction(parts);}return value;}
}const fraction = new Fraction(1, 2);
const stringified = JSON.stringify(fraction);
console.log(stringified);// "1/2"
const revived = JSON.parse(stringified, Fraction.fromJSON);
console.log(revived);
// Fraction { numerator: 1, denominator: 2 }

我们可以传递第二个参数JSON.parse来指定 reviver 函数。恢复器的工作是将字符串化数据“恢复”回其原始形式。在这里,我们传递了一个 reviver,它是类的静态fromJSON属性Fraction。

在这种情况下,reviver 检查该值是否是一个有效的分数,如果是,它会创建一个新Fraction对象并返回它。

有趣的事实:此功能用于内置的 Date 对象。尝试查找Date.prototype.toJSON
这就是为什么它有效:

console.log(JSON.stringify(new Date()))
//=> '"2022-03-01T06:28:41.308Z"'

要恢复日期,我们可以使用JSON.parse:

function reviveDate(key, value) {const regex = /^\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}(\.\d{1,}|)Z$/;if (typeof value === "string" && regex.test(value)) {return new Date(value);}return value;
}
console.log(JSON.parse('"2022-03-01T06:28:41.308Z"', reviveDate))
//=> Tue Mar 01 2022 06:28:41 GMT-0700 (Pacific Daylight Time)

5、使用revivers隐藏数据

与解析器一样,恢复器也可用于隐藏数据。它以相同的方式工作。

这是一个例子:

const user = JSON.stringify({name: 'John',password: '12345',age: 30
});console.log(JSON.parse(user, (key, value) => {if (key === 'password') {return;}return value;
}));

这是输出:
{ name: 'John', age: 30 }

本文完~

学习更多技能

请点击下方公众号

分享 5 个使用 JSON 相关方法的小技巧相关推荐

  1. 分享五个使用 JSON 相关方法的小技巧

    1.格式化 默认的字符串化器还会缩小 JSON,看起来很难看 const user = {name: 'John',age: 30,isAdmin: true,friends: ['Bob', 'Ja ...

  2. Golang 中使用 JSON 的一些小技巧 陶文 陶文 3 个月前 有的时候上游传过来的字段是string类型的,但是我们却想用变成数字来使用。 本来用一个json:,string 就可以支持了

    Golang 中使用 JSON 的一些小技巧 陶文 3 个月前 有的时候上游传过来的字段是string类型的,但是我们却想用变成数字来使用. 本来用一个json:",string" ...

  3. ps背景不变换字_分享五个超级实用的PS小技巧

    今天西瓜给大家分享五个PS的小技巧,特别容易上手操作而且很实用! 1.利用剪切蒙版给衣服加图案 首先第一步我们打开素材,使用快速选择工具,把裙子选出来,然后Ctrl+J复制出来 打开花纹背景素材,Ct ...

  4. 分享几点Android 开发中的小技巧吧。不知道算不算?

    也不想多说多,就拿几点来给大家分享吧: Android 在XML里面共享同一布局文件 使用XML的方式为背景添加渐变的效果 如何用代码自定义Android 自动生成的标题? 在ActivityGrou ...

  5. 常用aso优化技巧,分享ASO关键词优化的几个小技巧

    ASO关键词重要的内容如果优化过度,容易出现被苹果惩罚,所以对于关键词优化干货部分在实际操作中一定不能操作过度,防止被惩罚,干货部分仅仅适合于有学习或者补充ASO优化关键词部分使用.接下来我们一起看看 ...

  6. PDF转图片怎么转换?分享两个好用的转换小技巧

    怎么把PDF文件转换成图片呢?大家在日常办公中经常会使用到PDF文件,有的文件内容会非常多,而我们并不需要使用到这么多的内容,有的小伙伴会直接截图需要的那部分内容,但是这样可能会影响到图片的清晰度,其 ...

  7. 安卓手机卡顿怎么解决_手机卡顿?分享一个解决安卓手机卡顿的小技巧

    用安卓手机的小伙伴们都会发现一个现象,几乎所有的安卓手机用久了都会卡,哪怕是到了今天,安卓的手机运存已经达到了惊人的12GB,当后台运行的程序过多的时候还是惠有一丝丝的卡顿,这是为什么呢? 其实其归根 ...

  8. 分享一个使用Matchvs很实用的小技巧

    最近用游戏服务器引擎Matchvs开发了一款游戏,发现他们家的API还是很丰富的,只是在使用的过程中发现需要监听的回调有些多,写起来很麻烦,就把回调封装了一些,记录下来,以后再其他项目中使用,同时分享 ...

  9. 怎么把图片拼在一起?分享几种简单好用拼图小技巧

    无论是在艺术.摄影.设计等领域,还是在日常生活中,将照片拼接在一起都是一种有趣.有意义的方式,能够让照片更加生动.表现力更强,给人留下更深刻的印象.我们日常中发朋友圈会经常使用到拼图,下面给大家分享几 ...

最新文章

  1. 共同创造最好的OS,openEuler Developer Day 报名通道开启
  2. objective-c 逐帧动画
  3. Windows 7技巧之Telnet组件消失之迷
  4. testng重跑和框架亮点
  5. C#事件(event)解析(转)
  6. 漫谈程序猿系列:无BUG不生活
  7. 【学习资料JS】Vue官方文档下载
  8. 破解WMV格式电影的许可证
  9. 51单片机引脚功能介绍
  10. 两天两夜,1M图片优化到100kb
  11. 7-85 根据输入的空气污染指数,输出相应的信息。
  12. LaTeX插入视频示例
  13. 32位计算机装64位操作系统,电脑应该装32位还是64位系统?
  14. 输出三位数的个十百位数
  15. matlab基础语法
  16. 2021-08-14 WPF控件专题 ContextMenu 控件详解
  17. 汇编语言实验十完整代码和详细解析
  18. MySql保留两位小数
  19. 分享一款基于Micro Bit 的遥控小车的设计
  20. Linux 下编译自己的 OpenJDK7 包括JVM和JDK API

热门文章

  1. 【R语言学习笔记】rep函数
  2. 微信小程序nodejs+vue剧本杀游戏设计与实现
  3. 一文尽览 | 全景/鱼眼相机低速自动驾驶的近距离感知(识别+重建+定位+工程化)...
  4. List.removeAll()失效?
  5. centos 动画演示
  6. mysql 5.0 utf8mb4_MySQL 5.5将字符集从utf8升级为utf8mb4
  7. DNN学习笔记 最简单的皮肤制作
  8. 黑苹果facetime_苹果如何将增强现实整合到FaceTime中,但尚未实现
  9. 关于FPGA,小白的入门手册,高手的晋升宝典。
  10. android 调用相册功能吗,Android调用系统相册选择图片,支持小米4云相册