使用filter方法和includes方法实现:
const A = [1, 2, 3, 4, 5];
const B = [3, 4, 5, 6, 7];
const result = A.filter(item => !B.includes(item));
console.log(result); // [1, 2]
首先定义两个数组A和B,然后使用filter方法对A数组进行过滤,只保留不在B数组中的元素。在filter方法的回调函数中,使用includes方法判断该元素是否在B数组中,如果不在,则返回true,否则返回false。最后将过滤后的结果打印输出。
使用for循环和indexOf方法实现:
const A = [1, 2, 3, 4, 5];
const B = [3, 4, 5, 6, 7];
const result = [];
for (let i = 0; i < A.length; i++) {
if (B.indexOf(A[i]) === -1) {
result.push(A[i]);
}
}
console.log(result); // [1, 2]
同样定义两个数组A和B,然后使用for循环遍历A数组的每个元素,在循环中使用indexOf方法判断该元素是否在B数组中,如果不在,则将该元素添加到结果数组中。最后将结果数组打印输出。
使用Set和差集运算符实现:
const A = [1, 2, 3, 4, 5];
const B = [3, 4, 5, 6, 7];
const setA = new Set(A);
const setB = new Set(B);
const result = [...setA].filter(item => !setB.has(item));
console.log(result); // [1, 2]
首先定义两个数组A和B,然后将它们分别转化为Set对象。然后使用差集运算符(…setA] - …setB)获取在setA中但不在setB中的元素,最后使用filter方法过滤出结果数组。最后将结果数组打印输出。