您好,登錄后才能下訂單哦!
JS 中有許多常見(jiàn)的函數(shù),我們可能每天都在使用它們,但是卻不知道它們的一些額外功能。JSON.stringify
就是這樣的一個(gè)函數(shù),今天就來(lái)看下它的特殊用法。
基礎(chǔ)
JSON.stringify
方法接收一個(gè)變量,并將它轉(zhuǎn)換成 JSON 表示形式。
const boy = { name: 'John', age: 23 }; JSON.stringify(boy); // {"name":"John","age":23}
JSON 就是純字符串,它本質(zhì)上是 JS 的一個(gè)子集,所以并不是所有的 JS 對(duì)象都能轉(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 對(duì)象就會(huì)被忽略并轉(zhuǎn)換為普通對(duì)象。而如果屬性是函數(shù)的話(huà)則這個(gè)屬性就會(huì)被忽略,感興趣的同學(xué)可以試下。
第二個(gè)參數(shù)
JSON.stringify
可以接收第二個(gè)參數(shù),可以稱(chēng)為 replacer
替換器。
你可以傳入一個(gè)字符串?dāng)?shù)組,這個(gè)數(shù)組中具有的屬性才會(huì)被轉(zhuǎn)換,就像一個(gè)白名單。
const boy = { name: 'John', age: 23 } JSON.stringify(boy, ['name']) // {"name":"John"}
我們可以利用這個(gè)特性,只轉(zhuǎn)換需要轉(zhuǎn)換的屬性,過(guò)濾掉如很長(zhǎng)的數(shù)組、錯(cuò)誤對(duì)象等。
這個(gè) replacer
參數(shù)還可以接收一個(gè)函數(shù)。這個(gè)函數(shù)會(huì)遍歷整個(gè)對(duì)象,并將鍵和值傳入,讓你決定該如何替換它們。
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
不行),就將這個(gè)屬性移除了:
JSON.stringify(boy, (key, value) => { if (typeof value === 'string') { return undefined } return value }) // {"age":23,"hobbies":{}}
第三個(gè)參數(shù)
第三個(gè)參數(shù) space
控制了轉(zhuǎn)換后的 JSON 串的間距。
如果參數(shù)是數(shù)字,則以該數(shù)字個(gè)數(shù)的空格進(jìn)行縮進(jìn):
JSON.stringify(boy, null, 2) // { // "name": "John", // "age": 23, // "hobbies": {} // }
而如果參數(shù)是字符串,則以該字符串進(jìn)行縮進(jìn):
JSON.stringify(boy, null, '--') // { // --"name": "John", // --"age": 23, // --"hobbies": {} // }
toJSON 方法
如果我們要轉(zhuǎn)換的對(duì)象具有一個(gè) toJSON
方法,那么就可以定制自己被序列化的過(guò)程。您可以從方法中返回一個(gè)新值,而不是序列化該對(duì)象,并且此值將被序列化,而不是原始對(duì)象。
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 用法的詳細(xì)內(nèi)容,更多請(qǐng)關(guān)注億速云其它相關(guān)文章!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。