当前位置:首页 > 经验笔记 > javascript > 正文内容

js数组取交集、并集、差集、补集

han32681年前 (2024-01-18)javascript1774

一、简单数组

let arrA = [1,2,3,4]
let arrB = [4,5,6,7]
// 取交集
let res1  = arrA.filter(item => arrB.includes(item))
 
// 取并集
// 方法一
let res2  = Array.from(new Set([...arrA,...arrB]))
// 方法二
res2  = arrA.concat(arrB.filter(item => arrA.indexOf(item) === -1))
 
// 取差集 arrA相对于arrB所没有的
// 方法一
let res3  = arrA.filter(item => arrB.indexOf(item) === -1)
// 方法二 arrB相对于arrA所没有的
let res4 = arrB.filter(item => !new Set(arrA).has(item))
 
// 取补集 两个数组各自没有的集合
let res5 = [...res3,...res4]
 
console.log(arrA,arrB)
console.log("取交集",res1)
console.log("取并集",res2)
console.log("取差集, arrA相对于arrB所没有的",res3)
console.log("取差集, arrB相对于arrA所没有的",res4)
console.log("取补集",res5)

image.png


一、数组对象

let arrObjA = [{code:1,name:'A'},{code:2,name:'B'},{code:3,name:'C'}]
let arrObjB= [{code:3,name:'C'},{code:4,name:'D'},{code:5,name:'E'}]
 
 
// 取交集:取公共的
let res1  = arrObjA.filter(itemA => arrObjB.findIndex(itemB => itemA.code === itemB.code) > -1)
 
// 取并集:两个数组合并并去重
let res2  = arrObjA.concat(arrObjB.filter(itemB => arrObjA.findIndex(itemA => itemA.code == itemB.code) == -1))
 
 
// 取差集  arrA相对于arrB所没有的
let res4 = arrObjA.filter(itemA => !arrObjB.find(itemB => itemA.code == itemB.code))
// 取差集  arrB相对于arrA所没有的
let res5 = arrObjB.filter(itemB => !arrObjA.find(itemA => itemA.code == itemB.code))
 
// 取补集 两个数组各自没有的集合
let res6 = [...res4,...res5]
 
 
 
console.log(arrObjA,arrObjB)
console.log("取交集",res1)
console.log("取并集",res2)
console.log("取差集, arrB相对于arrA所没有的",res5)
console.log("取补集",res6)

image.png

扫描二维码推送至手机访问。

版权声明:本文由瀚文博客发布,如需转载请注明出处。

本文链接:https://hanwenblog.com/post/96.html

分享给朋友:

相关文章

JS/VUE按钮点击excel上传文件解析文件内容

代码如示    import * as XLSX from 'xlsx'; // 导入xlsx库    ...

axios下载文件

      api         .getAllAlar...

ES6 find 和 filter 的区别

遇到个功能是要分类就想说在前端过滤,不要从查数据库的时候过滤了。然后就想说除了filter还有啥好用的发现有个find,测试一番之后发现const list = [{&#...

Echarts图表的悬浮框位置的调整

下面的代码实现了悬浮框的位置不会超出界面 最多在离界面边缘5px的地方tooltip: {         ...

layer弹层遮罩挡住窗体解决,解决layer弹层遮罩挡住窗体的问题

layer弹层遮罩挡住窗体解决,解决layer弹层遮罩挡住窗体的问题

上代码<div>     <div>这里面某个按钮触发弹层<div>     &...