首頁 > web前端 > js教程 > 如何在 JavaScript 中有效地從陣列中刪除重複的物件?

如何在 JavaScript 中有效地從陣列中刪除重複的物件?

Patricia Arquette
發布: 2024-12-19 06:10:54
原創
672 人瀏覽過

How to Efficiently Remove Duplicate Objects from an Array in JavaScript?

如何從陣列中刪除重複的物件

使用物件陣列時,通常需要刪除重複項。 ES6 過濾方法為此任務提供了一個優雅的解決方案。

ES6 Magic

obj.arr = obj.arr.filter((value, index, self ) =>
索引=== self.findIndex ((t) =>; (

t.place === value.place && t.name === value.name
登入後複製

))
)

此程式碼將陣列中的每個元素與所有後續元素進行比較。如果找到重複項,則會將其過濾掉。

通用解決方案

更通用的方法:

const uniqueArray = obj. arr.filter((值, 索引) => {
const _value = JSON.stringify(value);
回傳索引=== obj.arr.findIndex(obj =>; {

return JSON.stringify(obj) === _value;
登入後複製

});
});

該策略將每個物件序列化為字串並比較字串以識別

基於屬性的比較

使用屬性策略:

const getUniqueItemsByProperties = (items, propNames) =>
items.filter((item, index, array) =>

index === array.findIndex(foundItem => isPropValuesEqual(foundItem, item, propNames))
登入後複製

);

此方法可以靈活地指定確定唯一性的屬性.

包裝屬性策略 h3>

允許陣列和單一屬性名稱:

const getUniqueItemsByProperties = (items, propNames) =>; {
const propNamesArray = Array.from(propNames);

return items.filter((item, index, array) =>

index === array.findIndex(foundItem => isPropValuesEqual(foundItem, item, propNamesArray))
登入後複製

);
};

解釋

這裡的關鍵思想是使用識別重複項的過濾方法。唯一性標準由比較邏輯決定,可以根據物件屬性或序列化策略進行自訂。

以上是如何在 JavaScript 中有效地從陣列中刪除重複的物件?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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