您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關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怎么用”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。