我有一个按钮,我通过读取数组和检查其属性禁用。
我的数组是这样的:
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)))