专业游戏门户,分享手游网游单机游戏百科知识攻略!

嗨游网
嗨游网

如何数组合并,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)方法。

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


本文地址:IT问答频道 https://www.eeeoo.cn/itwenda/936631.html,嗨游网一个专业手游免费下载攻略知识分享平台,本站部分内容来自网络分享,不对内容负责,如有涉及到您的权益,请联系我们删除,谢谢!


IT问答
小编:小嗨整编
相关文章相关阅读
  • javascript教程网(javascript教程推荐)

    javascript教程网(javascript教程推荐)

    javascript教程网(javascript教程推荐)JavaScript作为一种广泛应用于网页开发的技术,已经成为前端开发不可或缺的一部分。对于刚接触编程的菜鸟来说,选择一份合适的JavaScript教程至关重要。本文将为您推荐几款优...

  • 什么是构造函数?详解JavaScript中的构造函数

    什么是构造函数?详解JavaScript中的构造函数

    作为原型和原型链的基础,先了解清楚构造函数以及它的执行过程才能更好地帮助我们学习原型和原型链的知识。本篇文章带大家详细了解一下javascript中的构造函数,介绍一下怎么利用构造函数创建一个js对象,希望对大家有所帮助!一个普通的函数被用...

  • Javascript如何使网页跳转

    Javascript如何使网页跳转

    方法:1、使用_window.location.href方式;2、使用window.history.back方式;3、使用window.navigate方式;4、使用self.location方式;5、使用top.location方式。本教...

  • javascript中的设计模式有哪些

    javascript中的设计模式有哪些

    javascript中的设计模式有:单例模式、策略模式、代理模式、迭代器模式、“发布-订阅”模式、命令模式、组合模式、模板方法模式、享元模式、职责链模式、中介者模式、装饰者模式、状态模式、适配器模式、外观模式等。本教程操作环境:window...

  • JavaScript怎么使用pixi

    JavaScript怎么使用pixi

    pixi.js是一款轻量级的javascript库,用于创建2d游戏和交互式应用程序。其api简洁易用,提供了许多工具和特性,可以使开发者更快、更轻松地为游戏和应用程序创建精美的界面和用户体验。下面,我们来了解一下如何使用Pixi.j...

  • javascript中如何获取当前时间

    javascript中如何获取当前时间

    在javascript中,可以使用date对象中的date()方法来获取当前时间,该方法可返回当天的日期和时间;也可以使用“newdate()”创建一个时间对象,利用内置的时间读取方法,分别获取年、月、日、时、分、秒等信息。本教程操作环境...

  • JSF和JavaScript有什么区别

    JSF和JavaScript有什么区别

    区别:jsf是一种用于构建web应用程序的java框架,提供了一种以组件为中心来开发javaweb用户界面的方法,从而简化了开发。而javascript是一种解释型的脚本语言,被广泛用于web应用开发,常用来为网页添加各式各样的动态功能。...

  • ES6怎么求数组反转

    ES6怎么求数组反转

    在es6中,可以利用数组对象的reverse()方法来实现数组反转,该方法用于颠倒数组中元素的顺序,将最后一个元素放在第一位,而第一个元素放在最后,语法“array.reverse()”。reverse()方法会修改原始数组,如果不想修改需...

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

精彩推荐