javascript - 如何在 JavaScript 中从一个数组中过滤另一个数组中的对象?
问题描述
我有两个数组:
let channelList = [
{
"channelId": 1,
"channelName": "SMS"
},
{
"channelId": 2,
"channelName": "EMAIL"
},
{
"channelId": 3,
"channelName": "ANDROID"
},
{
"channelId": 4,
"channelName": "IOS"
}
]
和
let promoList = [
{
"id": 124,
"channelType": "SMS"
},
{
"id": 125,
"channelType": "ANDROID"
},
{
"id": 126,
"channelType": "IOS"
}
]
remainingChannels
我想要一个新的数组
{
"channelId": 2,
"channelName": "EMAIL"
}
因为它不存在于 中promoList
,但它存在于 中channelList
。
我正在尝试使用这样的过滤器操作来获取它:
for(let channel of this.promoDetailList) {
remainingChannels = this.channelList.filter(e => {
e.channelName == channel.channelType
});
}
这个怎么做?
解决方案
您可以使用Array.filter
和Array.some
let channelList = [{"channelId":1,"channelName":"SMS"},{"channelId":2,"channelName":"EMAIL"},{"channelId":3,"channelName":"ANDROID"},{"channelId":4,"channelName":"IOS"}];
let promoList = [{"id":124,"channelType":"SMS"},{"id":125,"channelType":"ANDROID"},{"id":126,"channelType":"IOS"}]
//Check if the `channelName` from `channels` is matching with any of the
//`channelType` from `promos` list, negate the result.
const filterData = (channels, promos) => channels.filter(channel => !promos.some(promo => promo.channelType === channel.channelName))
console.log(filterData(channelList, promoList));
这也可以使用Array.filter
和来实现Array.find
。
let channelList = [{"channelId":1,"channelName":"SMS"},{"channelId":2,"channelName":"EMAIL"},{"channelId":3,"channelName":"ANDROID"},{"channelId":4,"channelName":"IOS"}];
let promoList = [{"id":124,"channelType":"SMS"},{"id":125,"channelType":"ANDROID"},{"id":126,"channelType":"IOS"}]
const filterData = (channels, promos) => channels.filter(({ channelName }) => !promos.find(({ channelType }) => channelName === channelType));
console.log(filterData(channelList, promoList))