自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

JSON.stringify()的5個(gè)秘密特性

開發(fā) 前端
作為一名 JavaScript 開發(fā)人員,JSON.stringify() 是用于調(diào)試的最常見函數(shù)。但是它的作用是什么呢,難道我們不能使用 console.log() 來做同樣的事情嗎?讓我們試一試。

[[327422]]

 JSON.stringify() 方法能將一個(gè) JavaScript 對象或值轉(zhuǎn)換成一個(gè) JSON 字符串。

作為一名 JavaScript 開發(fā)人員,JSON.stringify() 是用于調(diào)試的最常見函數(shù)。但是它的作用是什么呢,難道我們不能使用 console.log() 來做同樣的事情嗎?讓我們試一試。   

  1. //初始化一個(gè) user 對象  
  2.    const user = {  
  3.     "name" : "Prateek Singh",  
  4.     "age" : 26  
  5.    }  
  6.    console.log(user);  
  7.    // 結(jié)果  
  8.    // [object Object] 

哦!console.log() 沒有幫助我們打印出期望的結(jié)果。它輸出 [object Object],因?yàn)閺膶ο蟮阶址哪J(rèn)轉(zhuǎn)換是 [object Object]。因此,我們使用 JSON.stringify() 首先將對象轉(zhuǎn)換成字符串,然后在控制臺(tái)中打印,如下所示。 

  1. const user = {  
  2.    "name" : "Prateek Singh",  
  3.    "age" : 26  
  4.   }  
  5.   console.log(JSON.stringify(user));  
  6.   // 結(jié)果  
  7.   // "{ "name" : "Prateek Singh", "age" : 26 }" 

一般來說,開發(fā)人員使用 stringify 函數(shù)的場景較為普遍,就像我們在上面做的那樣。但我要告訴你一些隱藏的秘密,這些小秘密會(huì)讓你開發(fā)起來更加輕松。

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

是的,stringify 函數(shù)也可以有第二個(gè)參數(shù)。它是要在控制臺(tái)中打印的對象的鍵數(shù)組??雌饋砗芎唵危孔屛覀兏钊胍稽c(diǎn)。我們有一個(gè)對象 product 并且我們想知道 product 的 name 屬性值。當(dāng)我們將其打印出來: 

  1. console.log(JSON.stringify(product)); 

它會(huì)輸出下面的結(jié)果。 

  1. {"id":"0001","type":"donut","name":"Cake","ppu":0.55,"batters":{"batter":[{"id":"1001","type":"Regular"},{"id":"1002","type":"Chocolate"},{"id":"1003","type":"Blueberry"},{"id":"1004","type":"Devil’s Food"}]},"topping":[{"id":"5001","type":"None"},{"id":"5002","type":"Glazed"},{"id":"5005","type":"Sugar"},{"id":"5007","type":"Powdered Sugar"},{"id":"5006","type":"Chocolate with Sprinkles"},{"id":"5003","type":"Chocolate"},{"id":"5004","type":"Maple"}]} 

在日志中很難找到 name 鍵,因?yàn)榭刂婆_(tái)上顯示了很多沒用的信息。當(dāng)對象變大時(shí),查找屬性的難度增加。stringify 函數(shù)的第二個(gè)參數(shù)這時(shí)就有用了。讓我們重寫代碼并查看結(jié)果。   

  1. console.log(JSON.stringify(product,['name' ]);  
  2.    // 結(jié)果  
  3.    {"name" : "Cake"} 

問題解決了,與打印整個(gè) JSON 對象不同,我們可以在第二個(gè)參數(shù)中將所需的鍵作為數(shù)組傳遞,從而只打印所需的屬性。

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

我們還可以傳入函數(shù)作為第二個(gè)參數(shù)。它根據(jù)函數(shù)中寫入的邏輯來計(jì)算每個(gè)鍵值對。如果返回 undefined,則不會(huì)打印鍵值對。請參考示例以獲得更好的理解。 

  1. const user = {  
  2.    "name" : "Prateek Singh",  
  3.    "age" : 26  
  4.   } 

 

  1. // 結(jié)果  
  2.   { "age" : 26 } 

只有 age 被打印出來,因?yàn)楹瘮?shù)判斷 typeOf 為 String 的值返回 undefined。

第三個(gè)參數(shù)為數(shù)字

第三個(gè)參數(shù)控制最后一個(gè)字符串的間距。如果參數(shù)是一個(gè)數(shù)字,則字符串化中的每個(gè)級別都將縮進(jìn)這個(gè)數(shù)量的空格字符。 

  1. // 注意:為了達(dá)到理解的目的,使用 '--' 替代了空格  
  2.  JSON.stringify(user, null, 2);  
  3.  //{  
  4.  //--"name": "Prateek Singh",  
  5.  //--"age": 26,  
  6.  //--"country": "India"  
  7.  //} 

第三個(gè)參數(shù)為字符串

如果第三個(gè)參數(shù)是 string,那么將使用它來代替上面顯示的空格字符。 

  1. JSON.stringify(user, null,'**');  
  2. //{  
  3. //**"name": "Prateek Singh",  
  4. //**"age": 26,  
  5. //**"country": "India"  
  6. //}  
  7. // 這里 * 取代了空格字符 

toJSON 方法

我們有一個(gè)叫 toJSON 的方法,它可以作為任意對象的屬性。JSON.stringify 返回這個(gè)函數(shù)的結(jié)果并對其進(jìn)行序列化,而不是將整個(gè)對象轉(zhuǎn)換為字符串。參考下面的例子。 

  1. const user = {  
  2.   firstName : "Prateek",  
  3.   lastName : "Singh",  
  4.   age : 26,  
  5.   toJSON() {  
  6.      return {   
  7.        fullName: `${this.firstName} + ${this.lastName}`  
  8.      };  
  9.   }  
  10.  }  
  11.  console.log(JSON.stringify(user));  
  12.  // 結(jié)果  
  13.  // "{ "fullName" : "Prateek Singh"}" 

這里我們可以看到,它只打印 toJSON 函數(shù)的結(jié)果,而不是打印整個(gè)對象。

我希望你能學(xué)到 stringify() 的一些基本特征。 

 

責(zé)任編輯:龐桂玉 來源: 前端大全
相關(guān)推薦

2020-03-29 20:16:09

JavaScript前端技術(shù)

2024-09-30 11:08:18

JSON局限性數(shù)據(jù)

2021-05-06 05:30:33

JSONstringify()parse()

2019-06-11 15:25:03

JSON性能前端

2021-12-11 18:59:35

JavascriptJSON應(yīng)用

2022-12-05 14:50:53

2021-12-22 09:08:39

JSON.stringJavaScript字符串

2023-01-17 16:25:18

前端開發(fā)JSON

2022-08-31 22:50:13

JavaScript函數(shù)JSON

2024-03-25 00:10:00

JSON后端開發(fā)

2025-04-21 10:43:21

2022-03-10 09:11:33

JavaScrip開發(fā)JSON

2024-05-08 08:32:25

架構(gòu)

2011-10-19 16:19:27

iOS 5蘋果

2015-06-11 09:55:49

程序員代碼

2011-08-17 10:04:13

vSphere 5虛擬化

2020-10-09 11:02:46

HTML5 特性

2023-05-12 08:11:58

JavaScriptJSON克隆

2023-05-08 09:00:46

JSON深拷貝對象

2019-12-05 12:11:37

DevOps開發(fā)應(yīng)用程序
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號