欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

你不知道的5個JavaScript中JSON的秘密功能分享

 更新時間:2023年05月31日 09:43:58   作者:前端小智  
在開發(fā)中,我們會經(jīng)常使用?JSON.stringify(object)?來序列化對象,但JSON.stringify方法除了了第一個參數(shù)外,還有其它參數(shù)可用,今天我們一起來看看這些參數(shù)是做啥的

在開發(fā)中,我們會經(jīng)常使用 JSON.stringify(object) 來序列化對象,但JSON.stringify方法除了了第一個參數(shù)外,還有其它參數(shù)可用,今天我們一起來看看這些參數(shù)是做啥的,Let's 開始。

1.格式化

默認的 JSON.stringify(object) 出來數(shù)據(jù)是一行字符串,這看起來很丑,如下所示:

const user = {
  name: '小智',
  age: 30,
  isAdmin: true,
  friends: ['隔壁老王', '小可愛'],
  address: {
    city: '天上人間',
  },
}
console.log(JSON.stringify(user))
// {"name":"小智","age":30,"isAdmin":true,"friends":["隔壁老王","小可愛"],"address":{"city":"天上人間"}}

JSON.stringify也有一個內(nèi)置的格式化器!

console.log(JSON.stringify(user, null, 2))
{
  "name": "小智", 
  "age": 30,      
  "isAdmin": true,
  "friends": [
    "隔壁老王",
    "小可愛"
  ],
  "address": {
    "city": "天上人間"
  }
}

(如果你想知道這個 null 是什么,我們以后再談)。

在這個例子中,JSON的格式化有2個空格的縮進。我們還可以指定一個自定義字符,用于縮進。

console.log(JSON.stringify(user, null, '【二哈】'))
{
【二哈】"name": "小智",
【二哈】"age": 30,
【二哈】"isAdmin": true,
【二哈】"friends": [
【二哈】【二哈】"隔壁老王",
【二哈】【二哈】"小可愛"
【二哈】],
【二哈】"address": {
【二哈】【二哈】"city": "天上人間"
【二哈】}
}

2.在序列化的數(shù)據(jù)中隱藏某些屬性

JSON.stringify 還有一個很少有人知道的第二個參,稱為 replacer,是一個函數(shù)或數(shù)組,決定哪些數(shù)據(jù)要保留在輸出中,哪些不要。

舉例一,假如,我們想隱藏用戶的密碼字段,可以這么做:

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

輸出:

{"name":"小智","age":30}

我們可以進一步重構(gòu):

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

輸出:

{"name":"小智","age":30}

你也可以傳遞一個數(shù)組:

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

輸出:

{"name":"小智","age":30}

最酷的是這對數(shù)組也有效,假設(shè)有如下的數(shù)組:

const poetry = [
  {
    name: '小智',
    content: [
      '興盡晚回舟,誤入藕花深處。',
      '鬼畜,鬼畜,單身百年手速。',
      '起點太高,于是期待太多,奢求太過,所以永不滿足。',
    ],
    tags: ['經(jīng)典', '魔幻', '鬼才'],
  },
  {
    name: '王大志',
    content: [
      '君子無非就是有耐心的狼。',
      '信者,無需誓言,不信者,誓言亦無助。'
    ],
    tags: ['經(jīng)典', '魔幻', '鬼才'],
  },
]

由于詩太過美麗,我想出名,最后輸出就想打出輸出關(guān)于名字的字段,那么也可以使用 JSON.stringify 來做:

console.log(JSON.stringify(poetry, ['name']))

輸出:

[{"name":"小智"},{"name":"王大志"}]

漂亮!

3.使用 toJSON 來創(chuàng)建自定義輸出格式

如果一個對象實現(xiàn)了 toJSON 函數(shù),JSON.stringify 將使用它來串化數(shù)據(jù)。

考慮一下這個例子:

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

輸出:

{"numerator":1,"denominator":2}

如果我們想讓輸出的結(jié)果是 1/2,那要怎么做呢?實現(xiàn) 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 根據(jù) toJSON 方法來解析,所以結(jié)果是 1/2

4.恢復(fù)數(shù)據(jù)

繼續(xù)上面的例子,如果我們想再次解析JSON時,分數(shù)會神奇被還原成原來的對象,這是不是很酷?我們可以這樣做:

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 傳遞第二個參數(shù)來指定一個 reviver 函數(shù)。reviver 的工作是將字符串化的數(shù)據(jù) "恢復(fù)"到它的原始形式。在這里,我們傳遞了一個reviver,它是 Fraction 類的靜態(tài)方法 fromJSON。

有趣的是:這個功能在內(nèi)置的Date對象中使用。試著查一下 Date.prototype.toJSON

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

為了恢復(fù)日期,我們可以使用 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 隱藏數(shù)據(jù)

stringify 一樣,parse也可以用來隱藏數(shù)據(jù)。它們工作方式是一樣的:

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 }

 以上就是你不知道的5個JavaScript中JSON的秘密功能分享的詳細內(nèi)容,更多關(guān)于JavaScript JSON的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • JavaScript實現(xiàn)的MD5算法完整實例

    JavaScript實現(xiàn)的MD5算法完整實例

    這篇文章主要介紹了JavaScript實現(xiàn)的MD5算法,以完整實例形式分析了基于JavaScript實現(xiàn)MD5算法的具體步驟與相關(guān)技巧,需要的朋友可以參考下
    2016-02-02
  • vscode?對?typescript代碼調(diào)試的步驟

    vscode?對?typescript代碼調(diào)試的步驟

    在VS?Code中,要對?TypeScript代碼進行調(diào)試,需要先編譯?TypeScript?代碼為JavaScript代碼,這篇文章主要介紹了vscode對typescript代碼調(diào)試的方法,需要的朋友可以參考下
    2023-03-03
  • 原生JS仿QQ閱讀點擊展開、收起效果

    原生JS仿QQ閱讀點擊展開、收起效果

    這篇文章主要為大家詳細介紹了原生JS仿QQ閱讀點擊展開、收起效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-03-03
  • 詳解JavaScript實現(xiàn)哈希表

    詳解JavaScript實現(xiàn)哈希表

    哈希表是一種非常重要的數(shù)據(jù)結(jié)構(gòu),幾乎所有的編程語言都有直接或者間接的應(yīng)用這種數(shù)據(jù)結(jié)構(gòu)。本文將為大家介紹通過JavaScript如何實現(xiàn)哈希表,以及哈希表的一些常用操作,需要的可以參考一下
    2021-12-12
  • JS實現(xiàn)拖動滑塊驗證

    JS實現(xiàn)拖動滑塊驗證

    這篇文章主要為大家詳細介紹了JS實現(xiàn)拖動滑塊驗證,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • 非常不錯的一個javascript 類

    非常不錯的一個javascript 類

    [綠色]非常不錯的一個javascript 類...
    2006-11-11
  • TypeScript中Class類的基本使用方法

    TypeScript中Class類的基本使用方法

    在TypeScript中,我們可以使用Class來定義類,這使得我們能夠更加結(jié)構(gòu)化地組織代碼并使用面向?qū)ο蟮乃枷脒M行開發(fā),本文小編將給大家詳細的總結(jié)一下TypeScript中Class類的基本語法,需要的朋友可以參考下
    2023-09-09
  • 基于element-ui?動態(tài)換膚的代碼詳解

    基于element-ui?動態(tài)換膚的代碼詳解

    這篇文章主要介紹了element-ui?動態(tài)換膚,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-03-03
  • JavaScript仿微博發(fā)布信息案例

    JavaScript仿微博發(fā)布信息案例

    這篇文章主要為大家詳細介紹了JavaScript仿微博發(fā)布信息案例,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-11-11
  • js 獲取class的元素的方法 以及創(chuàng)建方法getElementsByClassName

    js 獲取class的元素的方法 以及創(chuàng)建方法getElementsByClassName

    js 獲取class的元素的方法 以及創(chuàng)建方法getElementsByClassName,需要的朋友可以參考一下
    2013-03-03

最新評論