詳解JSON.stringify()的5個(gè)秘密特性
JSON.stringify() 方法能將一個(gè) JavaScript 對象或值轉(zhuǎn)換成一個(gè) JSON 字符串。
作為一名 JavaScript 開發(fā)人員,JSON.stringify() 是用于調(diào)試的最常見函數(shù)。但是它的作用是什么呢,難道我們不能使用 console.log() 來做同樣的事情嗎?讓我們試一試。
//初始化一個(gè) user 對象 const user = { "name" : "Prateek Singh", "age" : 26 } console.log(user); // 結(jié)果 // [object Object]
哦!console.log() 沒有幫助我們打印出期望的結(jié)果。它輸出 [object Object],因?yàn)閺膶ο蟮阶址哪J(rèn)轉(zhuǎn)換是 [object Object]。因此,我們使用 JSON.stringify() 首先將對象轉(zhuǎn)換成字符串,然后在控制臺中打印,如下所示。
const user = { "name" : "Prateek Singh", "age" : 26 } console.log(JSON.stringify(user)); // 結(jié)果 // "{ "name" : "Prateek Singh", "age" : 26 }"
一般來說,開發(fā)人員使用 stringify 函數(shù)的場景較為普遍,就像我們在上面做的那樣。但我要告訴你一些隱藏的秘密,這些小秘密會讓你開發(fā)起來更加輕松。
第二個(gè)參數(shù)(數(shù)組)
是的,stringify 函數(shù)也可以有第二個(gè)參數(shù)。它是要在控制臺中打印的對象的鍵數(shù)組??雌饋砗芎唵??讓我們更深入一點(diǎn)。我們有一個(gè)對象 product 并且我們想知道 product 的 name 屬性值。當(dāng)我們將其打印出來:
console.log(JSON.stringify(product));
它會輸出下面的結(jié)果。
{"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)榭刂婆_上顯示了很多沒用的信息。當(dāng)對象變大時(shí),查找屬性的難度增加。stringify 函數(shù)的第二個(gè)參數(shù)這時(shí)就有用了。讓我們重寫代碼并查看結(jié)果。
console.log(JSON.stringify(product,['name' ]); // 結(jié)果 {"name" : "Cake"}
問題解決了,與打印整個(gè) JSON 對象不同,我們可以在第二個(gè)參數(shù)中將所需的鍵作為數(shù)組傳遞,從而只打印所需的屬性。
第二個(gè)參數(shù)(函數(shù))
我們還可以傳入函數(shù)作為第二個(gè)參數(shù)。它根據(jù)函數(shù)中寫入的邏輯來計(jì)算每個(gè)鍵值對。如果返回 undefined,則不會打印鍵值對。請參考示例以獲得更好的理解。
const user = { "name" : "Prateek Singh", "age" : 26 }
// 結(jié)果
{ "age" : 26 }
只有 age 被打印出來,因?yàn)楹瘮?shù)判斷 typeOf 為 String 的值返回 undefined。
第三個(gè)參數(shù)為數(shù)字
第三個(gè)參數(shù)控制最后一個(gè)字符串的間距。如果參數(shù)是一個(gè)數(shù)字,則字符串化中的每個(gè)級別都將縮進(jìn)這個(gè)數(shù)量的空格字符。
// 注意:為了達(dá)到理解的目的,使用 '--' 替代了空格 JSON.stringify(user, null, 2); //{ //--"name": "Prateek Singh", //--"age": 26, //--"country": "India" //}
第三個(gè)參數(shù)為字符串
如果第三個(gè)參數(shù)是 string,那么將使用它來代替上面顯示的空格字符。
JSON.stringify(user, null,'**'); //{ //**"name": "Prateek Singh", //**"age": 26, //**"country": "India" //} // 這里 * 取代了空格字符
toJSON 方法
我們有一個(gè)叫 toJSON 的方法,它可以作為任意對象的屬性。JSON.stringify 返回這個(gè)函數(shù)的結(jié)果并對其進(jìn)行序列化,而不是將整個(gè)對象轉(zhuǎn)換為字符串。參考下面的例子。
const user = { firstName : "Prateek", lastName : "Singh", age : 26, toJSON() { return { fullName: `${this.firstName} + ${this.lastName}` }; } } console.log(JSON.stringify(user)); // 結(jié)果 // "{ "fullName" : "Prateek Singh"}"
這里我們可以看到,它只打印 toJSON 函數(shù)的結(jié)果,而不是打印整個(gè)對象。
我希望你能學(xué)到 stringify() 的一些基本特征。
到此這篇關(guān)于詳解JSON.stringify()的5個(gè)秘密特性的文章就介紹到這了,更多相關(guān)JSON.stringify()特性內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JS實(shí)現(xiàn)隨頁面滾動(dòng)顯示/隱藏窗口固定位置元素
窗口固定位置顯示元素,當(dāng)頁面高度大于某高度,并且頁面向下滾動(dòng)時(shí),顯示該元素;當(dāng)頁面位置小于某高度,或者頁面向上滾動(dòng)時(shí),隱藏該元素,下面通過本文給大家介紹JS實(shí)現(xiàn)隨頁面滾動(dòng)顯示/隱藏窗口固定位置元素,需要的朋友參考下吧2016-02-02給localStorage設(shè)置一個(gè)過期時(shí)間的方法分享
我們都知道localStorage不主動(dòng)刪除,永遠(yuǎn)不會銷毀,那么如何設(shè)置localStorage的過期時(shí)間呢?下面這篇文章主要給大家介紹了關(guān)于如何給localStorage設(shè)置一個(gè)過期時(shí)間的相關(guān)資料,需要的朋友可以參考下2018-11-11淺析JavaScriptSerializer類的序列化與反序列化
本篇文章主要介紹了JavaScriptSerializer類 對象序列化與反序列化的方法、屬性以及實(shí)例代碼,有需要的朋友可以參考一下2016-11-11每天一篇javascript學(xué)習(xí)小結(jié)(Function對象)
這篇文章主要介紹了javascript中的Function對象知識點(diǎn),對Function對象的基本使用方法,以及各種方法進(jìn)行整理,感興趣的小伙伴們可以參考一下2015-11-11js實(shí)現(xiàn)文本框中輸入文字頁面中div層同步獲取文本框內(nèi)容的方法
這篇文章主要介紹了js實(shí)現(xiàn)文本框中輸入文字頁面中div層同步獲取文本框內(nèi)容的方法,實(shí)例分析了javascript操作dom元素的技巧,需要的朋友可以參考下2015-03-03驗(yàn)證用戶是否修改過頁面的數(shù)據(jù)的實(shí)現(xiàn)方法
在實(shí)現(xiàn)程序的修改模塊時(shí),要在頁面端檢查用戶是否修改過數(shù)據(jù),以便提醒用戶及時(shí)保存修改后的數(shù)據(jù)。2008-09-09