首頁 > web前端 > js教程 > 使用Array.prototype.fill()時如何確保物件唯一?

使用Array.prototype.fill()時如何確保物件唯一?

Mary-Kate Olsen
發布: 2024-12-18 16:50:20
原創
259 人瀏覽過

How Can I Ensure Unique Objects When Using Array.prototype.fill()?

Array.prototype.fill():將物件作為引用傳遞

Array.prototype.fill() 方法是一個方便的實用程式使用指定值初始化數組。但是,當用物件填充數組時,物件將作為參考傳遞,而不是建立新實例。這種行為提出了一個問題:是否有辦法確保陣列的每個元素都是唯一的物件。

考慮以下範例:

var arr = new Array(2).fill({});
console.log(arr[0] === arr[1]); // true
登入後複製

在此範例中,有兩個物件建立並作為對 arr[0] 和 arr[1] 的引用傳遞。修改陣列的一個元素會影響另一個元素,因為它們是同一個物件:

arr[0].test = 'string';
console.log(arr[1].test); // 'string'
登入後複製

要使用Array.prototype.fill() 為陣列的每個元素建立一個新對象,您可以按照這些步驟:

  1. 使用fill()以任意值(例如未定義)填入數組
  2. 使用map()方法建立一個新數組,其中包含所需物件類型的新實例:
var arr = new Array(2).fill().map(u => ({}));
登入後複製

此方法確保數組的每個元素都是獨特的對象,與其他對象隔離:

arr[0].test = 'string';
console.log(arr[1].test); // undefined
登入後複製

以上是使用Array.prototype.fill()時如何確保物件唯一?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板