91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

javascript中JSON.stringify的用法

發布時間:2020-06-21 19:22:10 來源:億速云 閱讀:192 作者:鴿子 欄目:web開發

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

javascript中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"}

以上就是鮮為人知的 JSON.stringify 用法的詳細內容,更多請關注億速云其它相關文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

黑山县| 抚顺县| 宜昌市| 额尔古纳市| 湘阴县| 鄢陵县| 平昌县| 汉源县| 应城市| 龙岩市| 长白| 防城港市| 清新县| 西乌珠穆沁旗| 丽江市| 垦利县| 右玉县| 华容县| 滦平县| 建宁县| 峨山| 江阴市| 泌阳县| 洛隆县| 故城县| 大安市| 平昌县| 毕节市| 荔浦县| 佛山市| 揭阳市| 襄城县| 瑞昌市| 宝清县| 图木舒克市| 长治县| 陆川县| 乐清市| 湟中县| 寻乌县| 临泽县|