一、数组(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中数组的合并与去重相关推荐

  1. php合并一维数组,PHP中一维数组的合并与去重的方法

    这篇文章主要介绍了关于PHP中一维数组的合并与去重的方法,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下 合并数组的方法array_merge:数字键,直接往后添加,key重置 字符串键 ...

  2. js中数组的增删改查遍历迭代过滤

    注:最后附有源码,可自行测试,动动手印象更深刻 js中数组的增删改查.排序.遍历.迭代.过滤 1.展开语法 2.解构赋值 3.剩余解构 4.增删改 5.合并拆分 6.查 7.排序 8.遍历 9.迭代 ...

  3. js中数组常用的方法总结,包括ES6

    原文地址:js中数组常用的方法总结,包括ES6 1.push() 后增 push()方法可以向数组后添加一个新的元素,并返回新数组的长度. 末尾添加,返回长度,改变原数组 var a = [1,2,3 ...

  4. js中数组增删查改unshift、push、pop、shift、slice、indexOf、concat、join

    全栈工程师开发手册 (作者:栾鹏) js系列教程1-数组操作全解 js中数组增删查改 代码如下: //元素增加 var names=[]; //定义数组并初始化为空 names = ["小明 ...

  5. js中数组定义Array

    全栈工程师开发手册 (作者:栾鹏) js系列教程1-数组操作全解 js中数组定义 js中数组的定义非常简单,包含以下5中方式.不过首先要明确的是数组是Array类型的.不是基本数据类型 代码如下: v ...

  6. js中数组原型Array、自定义原型函数Array.prototype

    全栈工程师开发手册 (作者:栾鹏) js系列教程1-数组操作全解 js中数组原型.自定义原型函数 每个数组都包含length.prototype.constructor属性. 通过在prototype ...

  7. js中数组反向、排序reverse、sort

    全栈工程师开发手册 (作者:栾鹏) js系列教程1-数组操作全解 js中数组反向.排序 数组反向使用reverse函数,数组排序使用sort函数,排序函数可以传入比较函数,也可以修改数组圆形,自定义添 ...

  8. js中数组过滤、遍历、迭代every、some、filter、map、forEach、reduce、reduceRight

    全栈工程师开发手册 (作者:栾鹏) js系列教程1-数组操作全解 js中数组过滤.遍历.迭代 数组的过滤.遍历.迭代操作中 1.过滤为将满足条件的元素筛选出来,返回数组 2.遍历为分别计算每一个元素值 ...

  9. JS中数组迭代方法(JavaScript从入门到疯癫)

    数组迭代的方法包含了以下七个( map,filter,forEach,some,every, findIndex,reduce) 目录 1.map 2.filter 3.foreach 4.数组som ...

最新文章

  1. CTFshow 命令执行 web58
  2. 2020最后一个月,近4成应届生未就业,19个头部城市谁最留不住人?
  3. 可以直接反编译Mips架构的IDA版本(无需安装脚本)
  4. 数据挖掘的11大算法及python实现(个人笔记整理,非教学用)
  5. 机器人瓦力机械舞_25个与机器人有关的“前卫”知识,你知道几个?
  6. 实际返回的行数超出请求的行数_代码行数越少越好?
  7. ERP知识普及连载(21)
  8. javascript array map方法
  9. Luogu1514 引水入城
  10. HASP/Sentinel加密狗的服务器地址设置
  11. web前端面试之基础面试题(一)(含答案)
  12. oracle数据库怎么切换实例,oracle切换数据库实例
  13. 《老路用得上的商学课》46-50学习笔记
  14. 域名信息备案管理系统php,PHP:ICP备案查询PHP源代码
  15. Android签名验证与反调试机制的对抗技术
  16. sk hynix 固态硬盘 管理_256G固态硬盘哪个品牌的好?不妨看看这个
  17. Trino 本地编译搭建 standalone 模式
  18. 一个强化学习 Q-learning 算法的简明教程
  19. 播放数万 | 一文学会Cytoscape网络图绘制 - 最新教程
  20. QT设置窗口折叠效果QPropertyAnimation

热门文章

  1. html打印表格每页都有的表头和打印分页
  2. OI Journal
  3. input眼睛显示 vue_修改表单元素中placeholder属性样式、清除IE浏览器中input元素的清除图标和眼睛图标...
  4. linux中的如何进行磁盘分区
  5. 微信群变“赌窝” 零容忍
  6. Windows CMD命令 查看无线密码
  7. SSR——服务器端渲染(Vue)基础用法(一)
  8. ApkToolBox
  9. 微信小程序发放红包+领取红包(PHP)
  10. 查询域内计算机命令,AD域控Dsquery查询命令实列