javascript
JSON.stringify()还可以这么用
最近做項(xiàng)目的時候遇到一個對象深拷貝的問題,網(wǎng)上看了下發(fā)現(xiàn)最為簡便的方法是JSON.stringify(),比如你要深拷貝一個對象,可以這么做:
var test={a:"hello",b:"world",c:[{dd:"css",ee:"cdd"},{mm:"ff",nn:"ee"}] }; var testCopy = JSON.parse(JSON.stringify(test))這時你對testCopy變量的修改是不會影響到原來的test變量。
(注意,該方法有以下幾個問題。
1、會忽略?undefined
2、會忽略?symbol
3、不能序列化函數(shù)
4、不能解決循環(huán)引用的對象
5、不能正確處理new Date()
6、不能處理正則
)
然后比較好奇的又去MDN查了下文檔,發(fā)現(xiàn)JSON.stringify()還可以傳可選的參數(shù):
這里重點(diǎn)關(guān)注第二個參數(shù),可以傳一個函數(shù)或者數(shù)組。如上面文檔所說,如果該參數(shù)是函數(shù)的話被序列化的值的每個屬性都會經(jīng)過該函數(shù)的轉(zhuǎn)換和處理;如果該參數(shù)是數(shù)組,則只有包含在這個數(shù)組中的屬性名才會被序列化到最終的 JSON 字符串中;嗯,感覺挺有用處的:
看例子,傳函數(shù):
比如,你只是想取該對象屬性值為不為字符串的,就可以:
function replacer(key, value) {if (typeof value === "string") {return undefined;}return value; }var foo = {foundation: "Mozilla", model: "box", week: 45, transport: "car", month: 7}; var jsonString = JSON.stringify(foo, replacer);結(jié)果為:{"week":45,"month":7}.
傳數(shù)組:
JSON.stringify(foo, ['week', 'month']); // '{"week":45,"month":7}', 只保留“week”和“month”屬性值。這么一來,我們可以很方便的對一個復(fù)雜對象數(shù)據(jù)進(jìn)行簡單的過濾篩選,甚至可以省略遍歷屬性的循環(huán)取值。
?
轉(zhuǎn)載于:https://www.cnblogs.com/pjl43/p/10165943.html
總結(jié)
以上是生活随笔為你收集整理的JSON.stringify()还可以这么用的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 招人!阿里!!
- 下一篇: 再见Spring Security!推荐