站長資訊網(wǎng)
最全最豐富的資訊網(wǎng)站

鮮為人知的 JSON.stringify 用法

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

鮮為人知的 JSON.stringify 用法

基礎(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ù)的話則這個(gè)屬性就會(huì)被忽略,感興趣的同學(xué)可以試下。

第二個(gè)參數(shù)

JSON.stringify 可以接收第二個(gè)參數(shù),可以稱為 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)換的屬性,過濾掉如很長的數(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 方法,那么就可以定制自己被序列化的過程。您可以從方法中返回一個(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"}

是不是很有趣?有時(shí)候仔細(xì)看一些文檔還是很有用的~

參考文章

  • 原文地址: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教程 欄目,歡迎學(xué)習(xí)!

贊(0)
分享到: 更多 (0)
網(wǎng)站地圖   滬ICP備18035694號(hào)-2    滬公網(wǎng)安備31011702889846號(hào)
日韩亚洲精品福利| 日本精品一二三区| 国产成人精品无码免费看| jizz国产精品网站| 日韩美女va毛片在线播放| 国产日韩精品视频| 成年男女男精品免费视频网站| 亚洲精品天堂在线观看| 精品人人妻人人澡人人爽人人| 久久这里只有精品66re99| 国产A三级久久精品| 久久精品国产清自在天天线| 亚洲婷婷国产精品电影人久久| 精品一区二区三区在线观看l| 亚欧乱色国产精品免费视频| 依依成人精品视频在线观看| 国产精品视频免费一区二区三区| 亚洲AV成人精品日韩一区| 亚洲午夜精品久久久久久app| 国内少妇偷人精品视频免费| 国产成人精品免费视频软件| 青草久久精品亚洲综合专区| 日本午夜精品一区二区三区电影| 国产精品免费观看调教网| 日韩a在线观看免费观看| 国产在线精品观看一区| 日本精品一区二区三本中文| 国产精品无码一本二本三本色| 成人免费无码精品国产电影| 精品哟哟哟国产在线不卡| 日韩精品一区二区三区毛片| 国产精品美女乱子伦高| 国产精品亚洲专区在线播放| 国产精品免费综合一区视频| 国产精品久久久久久久久久久搜索| 国产在线视精品麻豆| 日韩av无码国产精品| 免费精品国产自产拍在线观看| 老司机精品视频免费| 合区精品久久久中文字幕一区| 国产精品天干天干在线综合|