3 回答

TA貢獻1886條經驗 獲得超2個贊
const filterKeys = {};
const filtered = arr.reduce((acc, item) => {
if (item.id === null || !(item.id in filterKeys)) {
filterKeys[item.id] = true;
acc.push(item);
}
return acc;
}, []);
在這種情況下,創建一個單獨的對象來跟蹤遇到的對象 ID filterKeys。
因為array是一個數組,所以做一個 reduce 來遍歷數組。如果id為 nuil 或未在 中找到filterKeys,則將該項目推入累加器并將其返回以用于下一次迭代。由于我們不關心為 null 的 id,因此它們沒有效果,因此不會被過濾掉。

TA貢獻1830條經驗 獲得超9個贊
使用下面的代碼,我用你的對象數組測試(工作):
arr.forEach(function (item) {
if (item.id == null) {
result.push(item);
}
else {
var index = result.findIndex(x => x.id == item.id);
if (index == -1)
{
result.push(item);
}
}
});
console.log(result)

TA貢獻1802條經驗 獲得超5個贊
你可以試試這個 -
const array = [{ id: 6652, value: 'erger' },{ id: 6652, value: 'sdfs' },{ id: 6653, value: 'sdgdfg' },{ id: 6000, value: 'trgd' },{ id: 6667, value: 'asdf' },{ id: 6667, value: 'fdg' },{ id: 6668, value: 'dfgr' },{ id: null, value: 'fg' },{ id: null, value: 'dfgdf' },{ id: null, value: 'fg' },{ id: null, value: 'dfgdf' },];
let index = 0;
const result = Object.values(
array.reduce(
(acc, curr) =>
curr.id === null ? { ...acc, [index++]: curr } : { ...acc, [curr.id]: curr },
{}
)
);
console.log(result);
.as-console-wrapper {min-height: 100%; top: 0}
添加回答
舉報