本文主要是分享关于 JavaScript 的 JSON 的一些小技巧,希望对大家有用。
1、格式化
默认的字符串化器还会缩小 JSON,看起来很难看:
const user = { name: '小张', age: 30, isAdmin: true, friends: ['小米', '小红'], address: { city: '北京', country: '中国' } }; console.log(JSON.stringify(user)); //=> {"name":"小张","age":30,"isAdmin":true,"friends":["小米","小红"],"address":{"city":"北京","country":"中国"}}
JSON.stringify
也有一个内置的格式化程序。
console.log(JSON.stringify(user, null, 2)); // { // "name": "小张", // "age": 30, // "isAdmin": true, // "friends": [ // "小米", // "小红" // ], // "address": { // "city": "北京", // "country": "中国" // } // }
(如果你想知道那个 null 是个什么东东,我们稍后会谈到)
在此示例中,JSON 格式为 2 个缩进空格。
我们还可以指定用于缩进的自定义字符。
console.log(JSON.stringify(user, null, 'lol')); // { // lol"name": "小张", // lol"age": 30, // lol"isAdmin": true, // lol"friends": [ // lollol"小米", // lollol"小红" // lol], // lol"address": { // lollol"city": "北京", // lollol"country": "中国" // lol} // }
2、隐藏字符串化数据中的某些属性
JSON.stringify 第二个参数,这在很大程度上是未知的。它被称为 replacer,它是一个函数或数组,用于决定哪些数据保留在输出中,哪些不保留。
这是一个简单的示例,我们可以在其中隐藏 password 用户。
const user = { name: '码云', password: '12345', age: 30 }; console.log(JSON.stringify(user, (key, value) => { if (key === 'password') { return; } return value; }));
这时输出:
{"name":"码云","age":30}
我们可以进一步重构:
function stripKeys(...keys) { return (key, value) => { if (keys.includes(key)) { return; } return value; }; } const user = { name: '码云', password: '12345', age: 30, gender: 'male' }; console.log(JSON.stringify(user, stripKeys('password', 'gender')))
输出:
{"name":"码云","age":30}
还可以传递一个数组来仅获取某些键:
const user = { name: '码云', 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-06-06T06:28:41.308Z"'
要恢复日期,我们可以使用JSON.parse
:
function reviveDate(key, value) { const regex = /^d{4}-d{2}-d{2}Td{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-06-06T06:28:41.308Z"', reviveDate))
5、使用 revivers 隐藏数据
与解析器一样,恢复器也可用于隐藏数据。它以相同的方式工作。
例子:
const user = JSON.stringify({ name: '码云', password: '12345', age: 30 }); console.log(JSON.parse(user, (key, value) => { if (key === 'password') { return; } return value; }));
这是输出:
{ name: '码云', age: 30 }
以上就是今天分享的 JavaScript 的 JSON 的一些小技巧,感谢阅读。