成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

分享五個使用 JSON 相關方法的小技巧

開發 前端
本文介紹一些關于 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 }

責任編輯:龐桂玉 來源: 前端大全
相關推薦

2010-11-12 10:13:46

數據中心改造

2010-02-24 11:22:04

WCF方法重載

2023-11-05 19:46:56

JavaIntelliJ代碼

2022-06-21 09:02:49

python技巧

2023-10-26 18:03:14

索引Python技巧

2022-07-15 15:30:13

Python技巧

2010-09-13 16:13:47

DIV CSS表單

2011-06-16 17:54:25

關鍵詞

2011-05-10 17:06:05

SEO

2011-11-22 13:55:42

遠程管理網絡管理

2022-05-24 14:07:53

OpenFeignSpring開源

2015-08-17 15:53:58

Linux桌面

2010-01-07 17:41:19

JSON定義法

2024-01-03 08:53:35

JavaScrip編程語言NodeJS

2011-07-15 17:35:19

JavaScript

2012-09-11 14:55:29

Moosefs

2011-03-11 16:25:53

Oracle數據庫

2015-07-27 09:36:09

storyboard

2022-04-02 09:56:44

pipPython

2011-06-28 13:56:43

JAVA
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 久久国产精品免费一区二区三区 | 亚洲国产一区二区三区 | 午夜在线视频一区二区三区 | 羞羞视频在线观免费观看 | 伊人性伊人情综合网 | a毛片 | 国内精品视频一区二区三区 | 精品三区 | 日韩在线精品强乱中文字幕 | 性一交一乱一伦视频免费观看 | 久久久久免费精品国产 | www.久久 | 亚洲一区中文字幕在线观看 | 国产精品美女久久久久久久网站 | 亚洲精品乱码久久久久v最新版 | 日日夜夜免费精品 | 青青艹在线视频 | 黄色一级视频 | 国产一区二区三区四区 | japan21xxxxhd美女 日本欧美国产在线 | 欧美日韩精品在线一区 | 日韩a视频 | 九九热精品在线 | 久久精品二区 | 一区精品视频在线观看 | 麻豆va| 在线成人福利 | 一a一片一级一片啪啪 | 国产毛片av| 亚洲精品一区二区三区中文字幕 | 欧美激情在线精品一区二区三区 | 欧美日韩在线看 | 亚洲第一视频 | 国产精品国产a | 久热久草 | 日韩小视频在线 | 自拍 亚洲 欧美 老师 丝袜 | 国产一区二区三区四区三区四 | 97超在线视频 | 成人一区二区三区 | 超碰在线人人 |