溫馨提示×

溫馨提示×

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

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

JSON.stringify怎么用

發(fā)布時間:2021-09-28 10:25:48 來源:億速云 閱讀:148 作者:小新 欄目:開發(fā)技術(shù)

這篇文章將為大家詳細講解有關(guān)JSON.stringify怎么用,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

基礎(chǔ)

JSON.stringify 方法接收一個變量,并將它轉(zhuǎn)換成 JSON 表示形式。

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

JSON 就是純字符串,它本質(zhì)上是 JS 的一個子集,所以并不是所有的 JS 對象都能轉(zhuǎn)換為 JSON:

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

上面的例子中 Map 對象就會被忽略并轉(zhuǎn)換為普通對象。而如果屬性是函數(shù)的話則這個屬性就會被忽略,感興趣的同學(xué)可以試下。

第二個參數(shù)

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

你可以傳入一個字符串?dāng)?shù)組,這個數(shù)組中具有的屬性才會被轉(zhuǎn)換,就像一個白名單。

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

我們可以利用這個特性,只轉(zhuǎn)換需要轉(zhuǎn)換的屬性,過濾掉如很長的數(shù)組、錯誤對象等。

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

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":{}}

第三個參數(shù)

第三個參數(shù) space 控制了轉(zhuǎn)換后的 JSON 串的間距。

如果參數(shù)是數(shù)字,則以該數(shù)字個數(shù)的空格進行縮進:

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

而如果參數(shù)是字符串,則以該字符串進行縮進:

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

toJSON 方法

如果我們要轉(zhuǎn)換的對象具有一個 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"}

關(guān)于“JSON.stringify怎么用”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學(xué)到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI