日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

JSON.stringify()还可以这么用

發(fā)布時間:2025/3/16 javascript 24 豆豆
生活随笔 收集整理的這篇文章主要介紹了 JSON.stringify()还可以这么用 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

最近做項(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)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。