JS合并两个数组的3种方法详解


Posted in Javascript onOctober 24, 2019

这篇文章主要介绍了JS合并两个数组的3种方法详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

需要将两个数组合并成为一个的情况。比如:

var a = [1,2,3];
var b = [4,5,6];

有两个数组a、b,需求是将两个数组合并成一个。方法如下:

1、concat

js的Array对象提供了一个叫concat()方法,连接两个或更多的数组,并返回结果。

var c = a.concat(b); //c=[1,2,3,4,5,6];

这里有一个问题,concat方法连接a、b两个数组后,a、b两个数组的数据不变,同时会返回一个新的数组。这样当我们需要进行多次的数组合并时,会造成很大的内存浪费,如果是数据量比较小的时候,还可以勉强用,如果数据量大的时候,这个就不妥了,所以这个方法肯定不是最好的。

2、for循环

大概的思路是:遍历其中一个数组,把该数组中的所有元素依次添加到另外一个数组中。直接上代码:

for( var i in b)
{
  a.push(b[i]);
}

这样的写法可以解决第一种方案中对内存的浪费,但是会有另一个问题:丑!这么说不是没有道理,如果能只用一行代码就搞定,岂不快哉~

3、apply

函数的apply方法有一个特性,那就是func.apply(obj,argv),argv是一个数组。所以我们可以利用这点,直上代码:
a.push.apply(a,b);

调用a.push这个函数实例的apply方法,同时把,b当作参数传入,这样a.push这个方法就会遍历b数组的所有元素,达到合并的效果。

这里可能有点绕,我们可以把b看成[4,5,6],变成这样:

a.push.apply(a,[4,5,6]);

然后上面的操作就等同于:

a.push(4,5,6);

这样就很清楚了!

另外,还要注意两个小问题:

1)以上3种合并方法并没有考虑过a、b两个数组谁的长度更小。

所以好的做法是预先判断a、b两个数组哪个更大,然后使用大数组合并小数组,这样就减少了数组元素操作的次数!

2)有时候我们不希望原数组(a、b)改变,这时就只能使用concat了。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JavaScript进阶练习及简单实例分析
Jun 03 Javascript
JS实现列表页面隔行变色效果
Mar 25 Javascript
vue.js动态数据绑定学习笔记
May 19 Javascript
js中json对象和字符串的理解及相互转化操作实现方法
Sep 22 Javascript
在Vue-cli里应用Vuex的state和mutations方法
Sep 16 Javascript
使用Vuex解决Vue中的身份验证问题
Sep 28 Javascript
angular中如何绑定iframe中src的方法
Feb 01 Javascript
详解vue引入子组件方法
Feb 12 Javascript
Element-ui DatePicker显示周数的方法示例
Jul 19 Javascript
Vue 封装防刷新考试倒计时组件的实现
Jun 05 Javascript
VUE项目实现主题切换的多种方法
Nov 26 Vue.js
jQuery实现查看图片功能
Dec 01 jQuery
js实现简单掷骰子小游戏
Oct 24 #Javascript
js实现GIF图片的分解和合成
Oct 24 #Javascript
js实现掷骰子小游戏
Oct 24 #Javascript
Element-Ui组件 NavMenu 导航菜单的具体使用
Oct 24 #Javascript
js实现GIF动图分解成多帧图片上传
Oct 24 #Javascript
js实现简单掷骰子效果
Oct 24 #Javascript
使用jQuery实现掷骰子游戏
Oct 24 #jQuery
You might like
PHP 获取目录下的图片并随机显示的代码
2009/12/28 PHP
php中stream(流)的用法
2014/03/25 PHP
php生成唯一数字id的方法汇总
2015/11/18 PHP
php使用lua+redis实现限流,计数器模式,令牌桶模式
2019/04/04 PHP
js遍历td tr等html元素
2012/12/13 Javascript
jQuery性能优化技巧分析
2015/02/20 Javascript
javascript实现日期按月份加减
2015/05/15 Javascript
JavaScript实现阿拉伯数字和中文数字互相转换
2016/06/12 Javascript
AngularJs Dependency Injection(DI,依赖注入)
2016/09/02 Javascript
分分钟玩转Vue.js组件(二)
2017/03/01 Javascript
jquery dataTable 获取某行数据
2017/05/05 jQuery
mui 打开新窗口的方式总结及注意事项
2017/08/20 Javascript
JavaScript实现焦点进入文本框内关闭输入法的核心代码
2017/09/20 Javascript
React/Redux应用使用Async/Await的方法
2017/11/16 Javascript
js利用递归与promise 按顺序请求数据的方法
2019/08/30 Javascript
[07:37]DOTA2-DPC中国联赛2月2日Recap集锦
2021/03/11 DOTA
MySQL中表的复制以及大型数据表的备份教程
2015/11/25 Python
TensorFlow实现RNN循环神经网络
2018/02/28 Python
将TensorFlow的模型网络导出为单个文件的方法
2018/04/23 Python
详解PyTorch批训练及优化器比较
2018/04/28 Python
python3 实现验证码图片切割的方法
2018/12/07 Python
python获取txt文件词向量过程详解
2019/07/05 Python
Python JSON编解码方式原理详解
2020/01/20 Python
Pycharm 使用 Pipenv 新建的虚拟环境(图文详解)
2020/04/16 Python
Python基于staticmethod装饰器标示静态方法
2020/10/17 Python
HTML5+lufylegend实现游戏中的卷轴
2016/02/29 HTML / CSS
使用C#编写创建一个线程的代码
2013/01/22 面试题
建筑专业自荐信
2013/10/18 职场文书
农贸市场管理制度
2014/01/31 职场文书
初中三好学生自我鉴定
2014/04/07 职场文书
生产工厂门卫岗位职责
2014/09/26 职场文书
会计专业求职信范文
2015/03/19 职场文书
民间借贷借条范本
2015/05/25 职场文书
中国合伙人观后感
2015/06/02 职场文书
教你使用Python pypinyin库实现汉字转拼音
2021/05/27 Python
css3 文字断裂效果
2022/04/22 HTML / CSS