const arr = '1'
const allArr = [
{id:1,name:'你好'}
{id:4,name:'再见'}
]
最终结果:
//screenArr = [{id:4,name:"再见"}];
实现如下:
const screenArr = allArr.filter((item) => {
return !arr.includes(item.id)
});
代码解析:
filter方法:创建一个新的数组,新数组中的元素是通过检查指定数组中符合条件的所有元素
语法:
array.filter(function(currentValue,index,arr), thisValue) //filter() 不会改变原始数组
参数说明:
currentValue 必须。当前元素的值
currentValue | 必须。当前元素的值 |
index | 可选。当前元素的索引值 |
arr | 可选。当前元素属于的数组对象 |
includes方法:includes() 方法用来判断一个数组是否包含一个指定的值,如果是返回 true,否则false。
[1, 2, 3].includes(3); // true
总结:
以上代码的意思就是说:使用filter创建一个新的数组(可以理解为是复制了allArr),遍历这个数组(allArr),找到匹配的数据之后,取反,所以这里return出去false,就过滤掉了