首頁 > 軟體

前端使用JSON.stringify實現深拷貝的巨坑詳解

2022-07-06 18:01:03

時間型別變成字串型別資料

當物件中有時間型別的元素時候-----時間型別會被變成字串型別資料

const obj = {
    date:new Date()
}
typeof obj.date === 'object' //true
const objCopy = JSON.parse(JSON.stringify(obj));
typeof objCopy.date === string; //true

然後你就會驚訝的發現,getTime()調不了了,getYearFull()也調不了了。就所有時間型別的內建方法都調不動了。

但,string型別的內建方法全能調了。

undefined和function直接丟失

當物件中有undefined型別或function型別的資料時 --- undefined和function會直接丟失

    const obj = {
        undef: undefined,
        fun: () => { console.log('嘰裡呱啦,阿巴阿巴') }
    }
    console.log(obj,"obj");
    const objCopy = JSON.parse(JSON.stringify(obj));
    console.log(objCopy,"objCopy")

然後你就會發現,這兩種型別的資料都沒了。

變成null

當物件中有NaN、Infinity和-Infinity這三種值的時候 --- 會變成null

1.7976931348623157E+10308 是浮點數的最大上線 顯示為Infinity

-1.7976931348623157E+10308 是浮點數的最小下線 顯示為-Infinity

    const obj = {
        nan:NaN,
        infinityMax:1.7976931348623157E+10308,
        infinityMin:-1.7976931348623157E+10308,
    }
    console.log(obj, "obj");
    const objCopy = JSON.parse(JSON.stringify(obj));
    console.log(objCopy,"objCopy")

當物件迴圈參照的時候 --會報錯

    const obj = {
        objChild:null
    }
    obj.objChild = obj;
    const objCopy = JSON.parse(JSON.stringify(obj));
    console.log(objCopy,"objCopy")

假如你有幸需要拷貝這麼一個物件 ↓

const obj = {
    nan:NaN,
    infinityMax:1.7976931348623157E+10308,
    infinityMin:-1.7976931348623157E+10308,
    undef: undefined,
    fun: () => { console.log('嘰裡呱啦,阿巴阿巴') },
    date:new Date,
}

然後你就會發現,好傢伙,沒一個正常的。

你還在使用JSON.stringify()來實現深拷貝嗎?

如果還在使用的話,小心了。作者推薦以後深拷貝使用遞迴的方式進行深拷貝。

javascript高階篇之實現深拷貝的四種方式 

這篇文章裡面有封裝好的可以進行深拷貝的遞迴函數,筆友可以自取。

總結

  • 物件中有時間型別的時候,序列化之後會變成字串型別。
  • 物件中有undefined和Function型別資料的時候,序列化之後會直接丟失。
  • 物件中有NaN、Infinity和-Infinity的時候,序列化之後會顯示null。
  • 物件迴圈參照的時候,會直接報錯。
  • 最後,深拷貝建議使用遞迴,安全方便。

以上就是JSON.stringify實現深拷貝的巨坑詳解的詳細內容,更多關於JSON.stringify深拷貝的資料請關注it145.com其它相關文章!


IT145.com E-mail:sddin#qq.com