JS中数组的合并与去重
一、数组(Array)的合并
1.forEach()遍历其中一个数组,将该数组的每一项push到另一个数组中
//遍历合并
let arr1 = [ 1, 2, 3, 4, 5];
let arr2 = [ 7, 8, 9, 4, 5];arr1.forEach( item => arr2.push(item) );
2.拓展运算符(ES6的)
//拓展运算符
let arr1 = [ 1, 2, 3, 4, 5];
let arr2 = [ 7, 8, 9, 4, 5];arr1.push( ...arr2 );
3.concat()一次合并多个数组(原数组不变,返回一个新数组)
//concat()合并多个数组
let arr1 = [ 1, 2, 3, 4, 5];
let arr2 = [ 7, 8, 9, 4, 5];
let arr3 = [ 10, 11, 12, 13, 14];let arr = arr1.concat(arr2, arr3);
4.使用apply()方法合并数组(apply(obj,array),其默认将array数组转化成一个参数列表)
//apply()合并数组
let arr1 = [ 1, 2, 3, 4, 5];
let arr2 = [ 7, 8, 9, 4, 5];arr1.push.apply(null, arr2); //相当于arr1.push(...arr2)
二、数组(Array)的去重
1.利用对象属性的唯一性去重(*个人比较推荐,在面对数组中每一项都是一个对象的时候,一些API是不生效的)
//利用对象属性的唯一性去重
let list = [{Staff_Code: "001", Staff_Name: "唐三"},{Staff_Code: "001", Staff_Name: "唐三"},{Staff_Code: "002", Staff_Name: "小舞"},{Staff_Code: "003", Staff_Name: "奥斯卡"}
];cutarray(arr) {let obj = {}; //obj用来记录该项重复出现了几次let brr = []; //brr是去重后的数组arr.forEach((item) => {if (obj[item.Staff_Code] == undefined) {obj[item.Staff_Code] = 1;brr.push(item);} else {obj[item.Staff_Code] += 1;}});return brr;
}let arr = this.cutarray(list);
2.递归去重(先给数组排序,然后相邻项判断是否相等,相等的用splice()截去。)
//递归去重(数组中存储的是原始(基本)数据类型,而非引用类型对象)cutarray(arr) {let len=arr.length;arr.sort((a,b) => a-b); //a-b升序;b-a降序function loop(index){if(index >= 1) {if(arr[index]===arr[index-1]) { arr.splice(index, 1);}loop(index-1)}}return arr;
}
3.利用filter()去重
// 如果新数组的当前元素的索引值 == 该元素在原始数组中的第一个索引,则返回当前元素
/**arr.indexOf(item),该方法将从头到尾地检索数组,看它是否含有对应的元素。如果找到一个item,则返回 item的"第一次出现的位置"。**/let list = arr.filter((item,index) => arr.indexOf(item) === index );
4.Set去重(ES6中的)
//Set去重
let list = [...new Set(arr)]; // arr需要去重的数组// 或者
let list1 = Array.form(new Set(arr));
JS中数组的合并与去重相关推荐
- php合并一维数组,PHP中一维数组的合并与去重的方法
这篇文章主要介绍了关于PHP中一维数组的合并与去重的方法,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下 合并数组的方法array_merge:数字键,直接往后添加,key重置 字符串键 ...
- js中数组的增删改查遍历迭代过滤
注:最后附有源码,可自行测试,动动手印象更深刻 js中数组的增删改查.排序.遍历.迭代.过滤 1.展开语法 2.解构赋值 3.剩余解构 4.增删改 5.合并拆分 6.查 7.排序 8.遍历 9.迭代 ...
- js中数组常用的方法总结,包括ES6
原文地址:js中数组常用的方法总结,包括ES6 1.push() 后增 push()方法可以向数组后添加一个新的元素,并返回新数组的长度. 末尾添加,返回长度,改变原数组 var a = [1,2,3 ...
- js中数组增删查改unshift、push、pop、shift、slice、indexOf、concat、join
全栈工程师开发手册 (作者:栾鹏) js系列教程1-数组操作全解 js中数组增删查改 代码如下: //元素增加 var names=[]; //定义数组并初始化为空 names = ["小明 ...
- js中数组定义Array
全栈工程师开发手册 (作者:栾鹏) js系列教程1-数组操作全解 js中数组定义 js中数组的定义非常简单,包含以下5中方式.不过首先要明确的是数组是Array类型的.不是基本数据类型 代码如下: v ...
- js中数组原型Array、自定义原型函数Array.prototype
全栈工程师开发手册 (作者:栾鹏) js系列教程1-数组操作全解 js中数组原型.自定义原型函数 每个数组都包含length.prototype.constructor属性. 通过在prototype ...
- js中数组反向、排序reverse、sort
全栈工程师开发手册 (作者:栾鹏) js系列教程1-数组操作全解 js中数组反向.排序 数组反向使用reverse函数,数组排序使用sort函数,排序函数可以传入比较函数,也可以修改数组圆形,自定义添 ...
- js中数组过滤、遍历、迭代every、some、filter、map、forEach、reduce、reduceRight
全栈工程师开发手册 (作者:栾鹏) js系列教程1-数组操作全解 js中数组过滤.遍历.迭代 数组的过滤.遍历.迭代操作中 1.过滤为将满足条件的元素筛选出来,返回数组 2.遍历为分别计算每一个元素值 ...
- JS中数组迭代方法(JavaScript从入门到疯癫)
数组迭代的方法包含了以下七个( map,filter,forEach,some,every, findIndex,reduce) 目录 1.map 2.filter 3.foreach 4.数组som ...
最新文章
- CTFshow 命令执行 web58
- 2020最后一个月,近4成应届生未就业,19个头部城市谁最留不住人?
- 可以直接反编译Mips架构的IDA版本(无需安装脚本)
- 数据挖掘的11大算法及python实现(个人笔记整理,非教学用)
- 机器人瓦力机械舞_25个与机器人有关的“前卫”知识,你知道几个?
- 实际返回的行数超出请求的行数_代码行数越少越好?
- ERP知识普及连载(21)
- javascript array map方法
- Luogu1514 引水入城
- HASP/Sentinel加密狗的服务器地址设置
- web前端面试之基础面试题(一)(含答案)
- oracle数据库怎么切换实例,oracle切换数据库实例
- 《老路用得上的商学课》46-50学习笔记
- 域名信息备案管理系统php,PHP:ICP备案查询PHP源代码
- Android签名验证与反调试机制的对抗技术
- sk hynix 固态硬盘 管理_256G固态硬盘哪个品牌的好?不妨看看这个
- Trino 本地编译搭建 standalone 模式
- 一个强化学习 Q-learning 算法的简明教程
- 播放数万 | 一文学会Cytoscape网络图绘制 - 最新教程
- QT设置窗口折叠效果QPropertyAnimation
热门文章
- html打印表格每页都有的表头和打印分页
- OI Journal
- input眼睛显示 vue_修改表单元素中placeholder属性样式、清除IE浏览器中input元素的清除图标和眼睛图标...
- linux中的如何进行磁盘分区
- 微信群变“赌窝” 零容忍
- Windows CMD命令 查看无线密码
- SSR——服务器端渲染(Vue)基础用法(一)
- ApkToolBox
- 微信小程序发放红包+领取红包(PHP)
- 查询域内计算机命令,AD域控Dsquery查询命令实列