对于 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 }
如果你还晓得任何其余很酷的JSON技巧,请畅言。
交换群
发表回复