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

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

han32682年前 (2024-01-18)javascript2083

一、简单数组

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://www.hanwenblog.com/post/96.html

分享给朋友:

相关文章

JS/VUE按钮点击上传文件

直接上代码    importFile() {       const fil...

echarts 第三方实例

一.前言。众所周知,在现今的开发大环境下,数据可视化(大屏化)项目在前端开发中的比重越来越大。而其中使用率最高的插件无疑就是 Apache Echarts。(ps: 以下简称为echarts)。本文就...

js遍历树,多层嵌,递归循环 elementUI Cascader 级联选择器数据结构拼接

js遍历树,多层嵌,递归循环 elementUI Cascader 级联选择器数据结构拼接

目的:后端传入数据和elementUI Cascader组件使用数据不一致 ,树形结构未知层级原始数据:{     "success":t...

ES6 find 和 filter 的区别

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

js把base64的数据转换成图片并上传

直接上代码,要点就是把base64转成Blob,添加到FormData传递给后台程序,跟选择图片文件上传时一样的了。//base64图片数据 var dataurl = ...