如何过滤数组,同时排除特定条件?



我有一个按钮,我通过读取数组和检查其属性禁用。

我的数组是这样的:

const arr = [
{id: ‘1’, name: ‘SOME_THING’, status: ‘AGREED’},
{id: ‘2’, name: ‘THIS_THING’, status: ‘AGREED’},
{id: ‘3’, name: ‘OTHER_THING’, status: ‘AGREED’},
{id: ‘4’, name: ‘EVERY_THING’, status: ‘AGREED’},
]; 

我当前禁用/启用此按钮的逻辑如下所示:

arr.filter((item) => item.indexOf(‘THING’) > -1)
.every((item) => item.status === ‘AGREED’)

现在我的要求改变了。我想以同样的方式启用/禁用按钮,但我想EXCLUDE此数组中的特定元素。例如,我想要排除这两个条目:

{id: ‘2’, name: ‘THIS_THING’, status: ‘AGREED’},
{id: ‘3’, name: ‘OTHER_THING’, status: ‘AGREED’},

使用我的逻辑,我如何过滤我的数组,同时排除这两个?

我意识到我可以尝试删除这些特定的项目,但我想知道是否有一种更干净的方法来做到这一点,而不是显式删除。

无论

的值是什么,只要始终假定给定的键/值对为真,就可以排除一个项列表。
const exclusionList = ['THIS_THING', 'OTHER_THING'];
arr.filter((item) => item.indexOf(‘THING’) > -1)
.every((item) => item.status === ‘AGREED’ || exclusionList.includes(item.name))

还请添加您的keyName(name)当你使用indexOf

let arr = [
{id: '1', name: 'SOME_THING', status: 'AGREED'},
{id: '2', name: 'THIS_THING', status: 'AGREED'},
{id: '3', name: 'OTHER_THING', status: 'AGREED'},
{id: '4', name: 'EVERY_THING', status: 'AGREED'},

]; 
const list = ['THIS_THING', 'OTHER_THING'];
console.log(arr.filter((item) => item.name.indexOf(‘THING’) > -1).every((user) => user.status === 'AGREED' || list.some(user.name)))

相关内容

  • 没有找到相关文章

最新更新