js中两个数组合并常用的方法

小黄鸭镇楼

题:将两个数组进行合并,如:[a, b, c]和[d, e, f]进行合并变成[a, b, c, d, e, f].

第一种方法

push加展开赋值(...)

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

let c = [
{name: '123', age: '123'},
{name: '456', age: '456'}];

let d = [
{name: '789', age: '789'},
{name: '789', age: '789'}];

a.push(...b);
console.log(a);

c.push(...d);
console.log(c);

push加展开赋值(...)代码
push加展开赋值(...)图片
注⚠️:push()方法的返回值是新数组的长度,所以[1, 2, 3].push(...[4, 5, 6]);返回的结果是6。

第二种方法

forEach+push

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

let c = [
{name: '123', age: '123'},
{name: '456', age: '456'}];

let d = [
{name: '789', age: '789'},
{name: '789', age: '789'}];

a.forEach((item) => {
b.push(item);
});
console.log(b);

c.forEach((item) => {
d.push(item);
});
console.log(d);

forEach+push代码
forEach+push结果

第三种方法

新数组+展开赋值(...)

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

let c = [
{name: '123', age: '123'},
{name: '456', age: '456'}];

let d = [
{name: '789', age: '789'},
{name: '789', age: '789'}];

let ab = [...a, ...b];
console.log(ab);

let cd = [...c, ...d];
console.log(cd);

新数组+展开赋值(...)代码
新数组+展开赋值(...)结果

第四种

concat

concat是js中Array自带的一个方法,用起来比较方便。

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

let c = [
{name: '123', age: '123'},
{name: '456', age: '456'}];

let d = [
{name: '789', age: '789'},
{name: '789', age: '789'}];

let ab = a.concat(b);
console.log(ab);

let cd = c.concat(d);
console.log(cd);

concat代码
concat结果

较为推荐后面两种方法。

当然,开一个新数组进行赋值效率更快一些,毕竟js底层c++数组都是定长,扩展js数组空间其实也是底层开辟新的空间,所以相对来说是更加推荐使用新数组+展开赋值的方式。当然你也可以使用foreach加push,只要你不怕在公司挨打。

有兴趣可以加入JavaScript交流群,和大佬们一起成长!!!

群号:348108867

QQ群
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • //JS数组常用方法及其应用/** * 1.push(): 向数组尾部添加一个或多个元素,并返回添加新元素后的数组...
    李二狗的星球阅读 3,508评论 0 0
  • 前言 最先接触编程的知识是在大学里面,大学里面学了一些基础的知识,c语言,java语言,单片机的汇编语言等;大学毕...
    oceanfive阅读 8,487评论 0 7
  • 第2章 基本语法 2.1 概述 基本句法和变量 语句 JavaScript程序的执行单位为行(line),也就是一...
    悟名先生阅读 9,739评论 0 13
  • 如果说命运就是奥特曼打小怪兽,猪脚剑斩反派boss,偶只想说,什么是正义,什么是邪恶,不过是笔者大大用"大宝剑"肆...
    飘飘倩影了无踪阅读 3,749评论 0 0
  • 冬去春来又一载 回眸望却多感慨 远处群峰息马力 不愿此生叹残年 人生如戏曲忧伤 草木一秋梦黄粱 待到江河重整日 谁...
    大韩天子阅读 3,532评论 4 3

友情链接更多精彩内容