专业汉语词典知识平台,分享汉字词语知识、历史文学知识解答!

励北网
励北网

如何数组合并,JavaScript合并数组的三种方法

来源:小易整编  作者:小易  发布时间:2023-03-22 08:13
摘要:如何数组合并,JavaScript合并数组的三种方法数组作为一种数据结构,表示索引项的有序集合。经常会使用到数组,尤其是将多个数组进行合并,比如将数组[1,2,3]和数组[4,5,6]合并,最终得到数组[1,2,3,4,5,6]。数组的合并...

如何数组合并,JavaScript合并数组的三种方法

如何数组合并,JavaScript合并数组的三种方法

数组作为一种数据结构,表示索引项的有序集合。经常会使用到数组,尤其是将多个数组进行合并,比如将数组 [1,2,3] 和 数组[4,5,6] 合并,最终得到数组[1,2,3,4,5,6]。

数组的合并分不可变合并和可变合并,前者将返回新的数组,不会改变被合并的数值,后者将改变被合并的数组。

数组的不可变合并

1、使用扩展运算符(...)合并

扩展运算符是合并数组的一种好方法,一定要掌握,其语法如下:

// 合并 array1 和 array2const mergeResult = [...array1, ...array2];

例如,让我们合并 2 个数组heroes和villains:

const heroes = ['Batman', 'Superman'];const villains = ['Joker', 'Bane'];const all = [...heroes, ...villains];console.log(all);  // ['Batman', 'Superman', 'Joker', 'Bane']

如上all 数组就是合并后返回的新数组,注意合并后的数组项将按照其原先的顺序进行排序。

当然我们可以一次合并多个数组,如下:

const mergeResult = [...array1, ...array2, ...array3, ...arrayN];

2、使用array.concat()方法合并

如果您更喜欢使用函数式方法来合并数组,那么您可以使用以下array1.concat(array2)方法:

// 合并 array1 和 array2const mergeResult = array1.concat(array2);

或使用另一种形式:

// 合并 array1 和 array2const mergeResult = [].concat(array1, array2);

array.concat()方法不会改变调用它的数组,而是返回一个具有合并结果的新数组。

例如,让我使用 concat 方法来合并数组heroes和villains:

const heroes = ['Batman', 'Superman'];const villains = ['Joker', 'Bane'];const all1 = heroes.concat(villains);const all2 = [].concat(heroes, villains);console.log(all1);// ['Batman', 'Superman', 'Joker', 'Bane']console.log(all2);// ['Batman', 'Superman', 'Joker', 'Bane']

以上2种方式合并后都会返回新的数组,如all1、all2。

concat 方法接受多个数组作为参数,因此您可以一次合并 2 个或多个数组:

const mergeResult = [].concat(array1, array2, array3, arrayN);

数组的可变合并

有时我们希望将一个数组合并到现有数组中,而不是返回一个新数组。下面的方法执行一种可变的合并方式。

1 使用array.push()方法合并

您可能已经知道array.push(item)方法会在数组末尾添加新的项,从而改变调用该方法的数组:

const heroes = ['Batman'];heroes.push('Superman');console.log(heroes); // ['Batman', 'Superman']

由于array.push(item1, item2, ..., itemN)接受多个要添加的项目,您可以使用应用于参数的扩展运算符将整个数组项添加到末尾(换句话说,执行合并):

// 将 array2 合并到 array1中array1.push(...array2);

例如,让我们合并villains到heroes数组中:

const heroes = ['Batman', 'Superman'];const villains = ['Joker', 'Bane'];heroes.push(...villains);console.log(heroes); // ['Batman', 'Superman', 'Joker', 'Bane']

heroes.push(...villains)将villains数组的所有项添加到heroes数组的末尾(执行可变合并)。heroes数组发生变化,而不是返回一个新的数组。

三、结论

JavaScript 提供了多种合并数组的方法。

您可以使用扩展运算符[...array1, ...array2]或函数式方法[].concat(array1, array2)来合并 2 个或更多数组。这些方法是不可变的,因为合并结果存储在一个新数组中。

如果您想执行可变合并,即合并到一个数组而不是创建一个新数组,那么您可以使用array1.push(...array2)方法。

您还知道哪些其他合并数组的方法?


本文地址:百科问答频道 https://www.neebe.cn/wenda/936631.html,易企推百科一个免费的知识分享平台,本站部分文章来网络分享,本着互联网分享的精神,如有涉及到您的权益,请联系我们删除,谢谢!


百科问答
小编:小易整编
相关文章相关阅读
  • JS 字符串转数组

    JS 字符串转数组

    JS中,将一个字符串转置为数组,使用到的方法是split(),通过使用split()方法,可以轻松的将一个字符串转换为数组操作方法01新建一个HTML文档,用于承载JS02...

  • 如何声明数组,声明数组的几种方式

    如何声明数组,声明数组的几种方式

    如何声明数组,声明数组的几种方式本节介绍数组的基础知识,包括数组的分类,以及如何声明数组。关于数组的内容相对抽象,会尽量介绍详尽。一、数组的分类1、按维度划分在上节中已经具体的介绍了VBA数组维度的概念。那么可以通过维度来划分数组,在VBA...

  • 如何数组合并,JavaScript合并数组的三种方法

    如何数组合并,JavaScript合并数组的三种方法

    如何数组合并,JavaScript合并数组的三种方法数组作为一种数据结构,表示索引项的有序集合。经常会使用到数组,尤其是将多个数组进行合并,比如将数组[1,2,3]和数组[4,5,6]合并,最终得到数组[1,2,3,4,5,6]。数组的合并...

  • 回到顶部如何实现,JavaScript实现回到顶部功能的五种方法

    回到顶部如何实现,JavaScript实现回到顶部功能的五种方法

    回到顶部如何实现,JavaScript实现回到顶部功能的五种方法回到顶部的功能现在基本上是网页的标配了,当你已经浏览到页面底部时,一键返回顶部的功能确实非常方便。随着用户习惯的养成,这个功能都是页面必备的。那么作为一个前端开发者,我们如何实...

  • 表单验证怎么实现,JavaScript实现表单验证方法

    表单验证怎么实现,JavaScript实现表单验证方法

    表单验证怎么实现,JavaScript实现表单验证方法一、前言 在Web项目开发中,经常会看到表单验证的功能。例如,用户注册、用户登录等,需要对用户填写的内容进行验证。接下来,小编带着大家一起来实现表单验证的用户名、密码、性别、手机号码、...

  • vb数组的基本操作,vb数组的用法

    vb数组的基本操作,vb数组的用法

    vb数组的基本操作,vb数组的用法本节课程,我们学习数组的基本操作。数组的基本操作包含:数组元素的输入输出、插入和删除元素、查询等。数组元素的输入在数组声明后,数组元素的值均为其数据类型的初始值,比如数值型初始值为0。因此,通常在正式使用数...

  • 数组函数是什么,数组函数使用技巧

    数组函数是什么,数组函数使用技巧

    数组函数是什么,数组函数使用技巧数组是按一定顺序排列的集合,简单来说就是一组数据。数组分为一维数组,二维数组1、一维数组分为横向,与纵向可以引用单元格数据创建数组,如下图(在公式中按F9显示内容)横向一维数组观察横向和纵向数组可以发现:数组...

  • js教程,JavaScript学习入门教程

    js教程,JavaScript学习入门教程

    js教程,JavaScript学习入门教程JavaScript(通常缩写为JS)是一种解释型、面向对象、多范式的高级编程语言。它被世界上的绝大多数网站所使用,也被世界主流浏览器(Chrome、IE、Firefox、Safari、Opera)...

  • 周排行
  • 月排行
  • 年排行

精彩推荐