真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

javascript中JSON.stringify的用法

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

山亭網(wǎng)站建設(shè)公司成都創(chuàng)新互聯(lián)公司,山亭網(wǎng)站設(shè)計(jì)制作,有大型網(wǎng)站制作公司豐富經(jīng)驗(yàn)。已為山亭近千家提供企業(yè)網(wǎng)站建設(shè)服務(wù)。企業(yè)網(wǎng)站搭建\成都外貿(mào)網(wǎng)站建設(shè)要多少錢,請(qǐng)找那個(gè)售后服務(wù)好的山亭做網(wǎng)站的公司定做!

javascript中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)換的屬性,過(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)注創(chuàng)新互聯(lián)其它相關(guān)文章!


網(wǎng)頁(yè)名稱:javascript中JSON.stringify的用法
文章位置:http://weahome.cn/article/iiosos.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部