首頁  >  文章  >  web前端  >  鮮為人知的 JSON.stringify 用法

鮮為人知的 JSON.stringify 用法

青灯夜游
青灯夜游轉載
2019-11-30 17:39:123027瀏覽

JS 中有許多常見的函數,我們可能每天都在使用它們,但卻不知道它們的一些額外功能。 JSON.stringify 就是這樣的一個函數,今天就來看看它的特殊用法。

鮮為人知的 JSON.stringify 用法

基礎

#JSON.stringify 方法接收一個變量,並將它轉換成JSON 表示形式。

const boy = { 
  name: 'John', 
  age: 23 
};

JSON.stringify(boy);
// {"name":"John","age":23}

JSON 就是純字串,它本質上是JS 的子集,所以並不是所有的JS 物件都能轉換為JSON:

const boy = { 
  name: 'John', 
  age: 23,
  hobbies: new Map([[0, 'coding'], [1, 'earn money']])
}

JSON.stringify(boy)
// {"name":"John","age":23,"hobbies":{}}

上面的範例中Map 物件就會被忽略並轉換為普通物件。而如果屬性是函數的話則這個屬性就會被忽略,有興趣的同學可以試下。

第二個參數

JSON.stringify 可以接收第二個參數,可以稱為 replacer 替換器。

你可以傳入一個字串數組,這個數組中具有的屬性才會被轉換,就像一個白名單。

const boy = { 
  name: 'John', 
  age: 23
}

JSON.stringify(boy, ['name'])
// {"name":"John"}

我們可以利用這個特性,只轉換需要轉換的屬性,過濾掉如很長的陣列、錯誤物件等。

這個 replacer 參數還可以接收一個函數。這個函數會遍歷整個對象,並將鍵和值傳入,讓你決定該如何替換它們。

const boy = { 
  name: 'John', 
  age: 23,
  hobbies: new Map([[0, 'coding'], [1, 'earn money']])
}

JSON.stringify(boy, (key, value) => {
  if (value instanceof Map) {
    return [...value.values()]
  }
  return value
})
// {"name":"John","age":23,"hobbies":["coding","earn money"]}

而如果你回傳了undefined (返回null 不行),就移除這個屬性了:

JSON.stringify(boy, (key, value) => {
  if (typeof value === 'string') {
    return undefined
  }
  return value
})
// {"age":23,"hobbies":{}}

#第三個參數

第三個參數space 控制了轉換後的JSON 字串的間距。

如果參數是數字,則以該數字個數的空格進行縮排:

JSON.stringify(boy, null, 2)
// {
//   "name": "John",
//   "age": 23,
//   "hobbies": {}
// }

而如果參數是字串,則以該字串進行縮排:

JSON.stringify(boy, null, '--')
// {
//   --"name": "John",
//   --"age": 23,
//   --"hobbies": {}
// }

toJSON 方法

如果我們要轉換的物件具有一個toJSON 方法,那麼就可以自訂自己被序列化的過程。您可以從方法中返回一個新值,而不是序列化該對象,並且此值將被序列化,而不是原始對象。

const boy = { 
  name: 'John', 
  age: 23,
  hobbies: new Map([[0, 'coding'], [1, 'earn money']]),
  toJSON() {
    return {
      name: `${this.name} (${this.age})`,
      favorite: this.hobbies.get(0)
    }
  }
}

JSON.stringify(boy)
// {"name":"John (23)","favorite":"coding"}

是不是很有趣?有時候仔細看一些文件還是很有用的~

參考文章

  • 原文網址:https:// mp.weixin.qq.com/s/_e83_G7RjVt2eR_ro7blOA

  • MDN:https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON /stringify

本文來自 js教學 欄目,歡迎學習!

以上是鮮為人知的 JSON.stringify 用法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:segmentfault.com。如有侵權,請聯絡admin@php.cn刪除