首頁 >web前端 >js教程 >如何在 JavaScript 中最好地深度複製互連物件數組?

如何在 JavaScript 中最好地深度複製互連物件數組?

Mary-Kate Olsen
Mary-Kate Olsen原創
2024-12-11 19:51:14261瀏覽

How to Best Deep Copy an Array of Interconnected Objects in JavaScript?

複製互連物件的陣列

使用複雜的資料結構時,例如引用同一數組中其他物件的物件數組,創建真正的深層複製可能具有挑戰性。讓我們探索各種方法:

使用StructuredClone 建立深度複製

深度複製的現代解決方案是使用StructuredClone():

array2 = structuredClone(array1);

此方法支援廣泛的的資料類型,並且大多數瀏覽器都支援。

使用以下命令建立深層副本JSON.parse

對於具有JSON 可序列化內容的對象,一個簡單的一行解決方案是:

let clonedArray = JSON.parse(JSON.stringify(nodesArray))

但是,與其他方法相比,它在不可序列化內容和效能問題方面有其限制。

使用Spread 運算子建立深度複製

如果您的陣列包含淺對象,則展開運算子與.map() 結合可用於快速且有效率的深度複製:

clonedArray = nodesArray.map(a => ({...a}));

此方法顯著優於JSON.parse。

注意事項

  • 效能:深度複製的效能可能會因資料結構的大小和複雜性而異。建議對不同的方法進行基準測試。
  • 相容性: StructuredClone() 需要相對較新的瀏覽器版本。如果擔心相容性,請使用替代方法。
  • 序列化與克隆:如果您的物件需要透過網路傳送,您可能需要考慮序列化而不是複製。

以上是如何在 JavaScript 中最好地深度複製互連物件數組?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn