”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > JavaScript 数组方法:综合指南

JavaScript 数组方法:综合指南

发布于2024-11-07
浏览:428

JavaScript Array Methods: A Comprehensive Guide

数组是 JavaScript 中最基本的数据结构之一。使用数组,您可以在单个变量中存储多个值。 JavaScript 提供了许多内置方法来操作数组,使它们具有令人难以置信的通用性。在这篇文章中,我们将探讨所有内置数组方法以及如何在 JavaScript 项目中有效地使用它们。

核心方法

forEach()

forEach() 方法允许您迭代数组并为数组中的每个元素执行一次提供的函数。这是循环数组的简单方法。

const array = [1, 2, 3, 4, 5];

array.forEach((element) => {
  console.log(element);
});

地图()

map() 方法创建一个新数组,其中填充了对数组中每个元素调用所提供函数的结果。它通常用于转换数据。

const array = [1, 2, 3, 4, 5];

const doubled = array.map((element) => element * 2);

console.log(doubled); // [2, 4, 6, 8, 10]

筛选()

filter() 方法创建一个新数组,其中包含通过所提供函数实现的测试的所有元素。当您需要根据条件从数组中过滤掉某些元素时,它非常有用。

const array = [1, 2, 3, 4, 5];

const evenNumbers = array.filter((element) => element % 2 === 0);

console.log(evenNumbers); // [2, 4]

减少()

reduce()方法对数组的每个元素执行reducer函数,产生单个输出值。它通常用于对值求和、累加总计或将数组合并为单个值。

const array = [1, 2, 3, 4, 5];

const sum = array.reduce((accumulator, currentValue) => accumulator   currentValue, 0);

console.log(sum); // 15

寻找()

find() 方法返回数组中满足所提供的测试函数的第一个元素的值。它在找到第一个匹配项后停止。

const array = [1, 2, 3, 4, 5];

const found = array.find((element) => element > 3);

console.log(found); // 4

查找索引()

findIndex() 方法返回数组中满足所提供的测试函数的第一个元素的索引。如果没有元素满足测试函数,则返回-1。

const array = [1, 2, 3, 4, 5];

const index = array.findIndex((element) => element > 3);

console.log(index); // 3

种类()

sort() 方法对数组的元素进行就地排序并返回排序后的数组。它通常用于对字符串和数字进行排序,但可能需要比较函数才能正确对数字进行排序。

const array = [5, 3, 8, 1, 2];

const sortedArray = array.sort((a, b) => a - b);

console.log(sortedArray); // [1, 2, 3, 5, 8]

撤销()

reverse() 方法就地反转数组的元素。第一个数组元素成为最后一个,最后一个成为第一个。

const array = [1, 2, 3, 4, 5];

const reversedArray = array.reverse();

console.log(reversedArray); // [5, 4, 3, 2, 1]

连接()

concat()方法用于合并两个或多个数组。它返回一个新数组,保持原始数组不变。

const array1 = [1, 2, 3];
const array2 = [4, 5, 6];

const concatenatedArray = array1.concat(array2);

console.log(concatenatedArray); // [1, 2, 3, 4, 5, 6]

片()

slice() 方法将数组的一部分浅拷贝返回到从头到尾(不包括 end)选择的新数组对象中。

const array = [1, 2, 3, 4, 5];

const slicedArray = array.slice(1, 4);

console.log(slicedArray); // [2, 3, 4]

拼接()

splice() 方法通过删除、替换或添加元素来更改数组的内容。

const array = [1, 2, 3, 4, 5];

array.splice(2, 1, 6, 7);

console.log(array); // [1, 2, 6, 7, 4, 5]

推()

push() 方法将一个或多个元素添加到数组末尾并返回数组的新长度。

const array = [1, 2, 3];

array.push(4, 5);

console.log(array); // [1, 2, 3, 4, 5]

流行音乐()

pop() 方法从数组中删除最后一个元素并返回该元素。

const array = [1, 2, 3, 4, 5];

const lastElement = array.pop();

console.log(lastElement); // 5
console.log(array); // [1, 2, 3, 4]

转移()

shift() 方法从数组中删除第一个元素并返回该元素。

const array = [1, 2, 3, 4, 5];

const firstElement = array.shift();

console.log(firstElement); // 1
console.log(array); // [2, 3, 4, 5]

取消移位()

unshift() 方法将一个或多个元素添加到数组的开头并返回数组的新长度。

const array = [2, 3, 4, 5];

array.unshift(1);

console.log(array); // [1, 2, 3, 4, 5]

加入()

join() 方法通过连接数组中的所有元素(以逗号或指定的分隔符字符串分隔)来创建并返回一个新字符串。

const array = [1, 2, 3, 4, 5];

const joinedString = array.join('-');

console.log(joinedString); // "1-2-3-4-5"

附加方法

每一个()

every() 方法测试数组中的所有元素是否通过提供的测试函数。

const array = [2, 4, 6, 8];

const allEven = array.every((element) => element % 2 === 0);

console.log(allEven); // true

一些()

some() 方法测试数组中至少一个元素是否通过提供的测试函数。

const array = [1, 2, 3, 4, 5];

const hasEven = array.some((element) => element % 2 === 0);

console.log(hasEven); // true

平坦的()

flat() 方法创建一个新数组,其中所有子数组元素递归地连接到其中,直到指定的深度。

const array = [1, [2, [3, [4]]]];

const flattenedArray = array.flat(2);

console.log(flattenedArray); // [1, 2, 3, [4]]

平面地图()

flatMap() 方法首先使用映射函数映射每个元素,然后将结果展平到一个新数组中。它是map()和flat()的组合。

const array = [1, 2, 3, 4];

const flattened = array.flatMap((num) => [num, num * 2]);

console.log(flattened); // [1, 2, 2, 4, 3, 6, 4, 8]

充满()

fill() 方法用静态值填充数组中从起始索引到结束索引的所有元素。

const array = [1, 2, 3, 4, 5];

array.fill(0, 2, 4);

console.log(array); // [1, 2, 0, 0, 5]

在()内复制

copyWithin() 方法将数组的一部分浅拷贝到同一数组中的另一个位置,而不修改其长度。

const array = [1, 2, 3, 4, 5];

array.copyWithin(0, 3, 5);

console.log(array); // [4, 5, 3, 4, 5]

包括()

includes() 方法检查数组是否包含某个值。

const array = [1, 2, 3, 4, 5];

const hasThree =

 array.includes(3);

console.log(hasThree); // true

toString()

toString()方法将数组转换为字符串,字符串之间用逗号分隔。

const array = [1, 2, 3, 4, 5];

const arrayString = array.toString();

console.log(arrayString); // "1,2,3,4,5"

索引()

indexOf() 方法返回在数组中可以找到给定元素的第一个索引,如果不存在则返回 -1。

const array = [1, 2, 3, 4, 5];

const index = array.indexOf(3);

console.log(index); // 2

最后索引()

lastIndexOf() 方法返回在数组中可以找到给定元素的最后一个索引,如果不存在则返回 -1。

const array = [1, 2, 3, 4, 3, 5];

const lastIndex = array.lastIndexOf(3);

console.log(lastIndex); // 4

从()

Array.from() 方法从类似数组或可迭代对象创建一个新的数组实例。

const array = Array.from('hello');

console.log(array); // ['h', 'e', 'l', 'l', 'o']

isArray()

Array.isArray()方法检查传递的值是否是数组。

const array = [1, 2, 3, 4, 5];
const notArray = { a: 1, b: 2 };

console.log(Array.isArray(array)); // true
console.log(Array.isArray(notArray)); // false

的()

Array.of() 方法创建一个具有可变数量元素的新数组实例。

const array1 = Array.of(1, 2, 3);
const array2 = Array.of('a', 'b', 'c');

console.log(array1); // [1, 2, 3]
console.log(array2); // ['a', 'b', 'c']

结论

JavaScript 数组具有多种内置方法,可以进行强大的数据操作。了解这些方法将使您更有效地编写干净简洁的代码。花一些时间尝试这些方法,看看它们如何改进您的代码。
最初发布:JavaScript 数组方法指南

版本声明 本文转载于:https://dev.to/who_tf_cares/javascript-array-methods-a-comprehensive-guide-4966?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 如何使用 MinGW 在 Windows 上构建 GLEW?分步指南。
    如何使用 MinGW 在 Windows 上构建 GLEW?分步指南。
    使用 MinGW 在 Windows 上构建 GLEW:综合指南使用 GLEW,这是一个无缝集成 OpenGL 和 WGL 函数的纯头文件库,使用 MinGW 增强 Windows 上 OpenGL 应用程序的开发。为了使用 MinGW 有效构建 GLEW,需要一组特定的命令和步骤。首先,创建两个名...
    编程 发布于2024-11-07
  • 如何使用 CSS 创建带有对角线的双色调背景?
    如何使用 CSS 创建带有对角线的双色调背景?
    使用对角线创建双色调背景要使用 CSS 实现由对角线分为两部分的背景,请执行以下操作这些步骤:1。创建两个 Div:创建两个单独的 div 来表示两个背景部分。2.设置 Div 样式:将以下 CSS 应用于 div:.solid-div { background-color: [solid co...
    编程 发布于2024-11-07
  • 文档的力量:阅读如何改变我在 JamSphere 上使用 Redux 的体验
    文档的力量:阅读如何改变我在 JamSphere 上使用 Redux 的体验
    作为开发人员,我们经常发现自己一头扎进新的库或框架,渴望将我们的想法变为现实。跳过文档并直接跳到编码的诱惑很强烈——毕竟,这有多难呢?但正如我通过构建音乐管理平台 JamSphere 的经验所了解到的那样,跳过这一关键步骤可能会将顺利的旅程变成充满挑战的艰苦战斗。 跳过文档的魅力 当...
    编程 发布于2024-11-07
  • 如何在PHP多子域应用中精准控制Cookie域?
    如何在PHP多子域应用中精准控制Cookie域?
    在 PHP 中控制 Cookie 域和子域创建多子域站点时,有必要控制会话 cookie 的域确保每个子域的正确会话管理。然而,手动设置域时,PHP 的 cookie 处理似乎存在差异。默认情况下,session_start() 会使用当前子域分配会话 cookie。但是,尝试使用 ini_set(...
    编程 发布于2024-11-07
  • Java中的三元运算符可以不返回值吗?
    Java中的三元运算符可以不返回值吗?
    三元运算符:深入研究代码优化虽然三元运算符 (?:) 是 Java 中的一个强大工具,但它了解其局限性至关重要。一个常见的误解是可以在不返回值的情况下使用它。与这种看法相反,Java 不允许在没有 return 语句的情况下进行三元运算。三元运算符的目的是评估条件并将值分配给变量或表达式。如果没有返...
    编程 发布于2024-11-07
  • 为什么您应该在下一个 PHP 项目中尝试 Lithe?
    为什么您应该在下一个 PHP 项目中尝试 Lithe?
    Lithe 是寻求简单性与强大功能之间平衡的开发人员的完美 PHP 框架。如果您厌倦了使开发缓慢且令人困惑的繁琐框架,Lithe 提供了一种极简但极其灵活的方法,旨在使您的工作更快、更高效。 1. 轻量且超快 Lithe 的开发重点是轻量级,允许您以很少的开销创建应用程序。与其他提供...
    编程 发布于2024-11-07
  • 如何处理 Android 中的互联网连接变化?
    如何处理 Android 中的互联网连接变化?
    处理 Android 中的互联网连接变化问题集中在需要一个可以监视互联网连接变化的广播接收器,因为现有代码仅检测连接变化。为了解决这个问题,这里有一个替代方法:public class NetworkUtil { public static final int TYPE_WIFI = 1; ...
    编程 发布于2024-11-07
  • Python 3.x 的 Super() 在没有参数的情况下如何工作?潜在的陷阱是什么?
    Python 3.x 的 Super() 在没有参数的情况下如何工作?潜在的陷阱是什么?
    Python 3.x 的超级魔法:解开谜团Python 3.x 在其 super() 方法中引入了令人惊讶的转折,允许无参数调用。这种看似无害的变化在幕后却带来了重大的后果和内在的魔力。揭开魔力为了维护 DRY 原则,新的 super() 行为绕过了显式类命名。它有一个特殊的 class 单元,用于...
    编程 发布于2024-11-07
  • Tailwind Flex:Flexbox 实用程序初学者指南
    Tailwind Flex:Flexbox 实用程序初学者指南
    Tailwind Flex 提供了一种创建响应式布局的有效方法,无需编写复杂的 CSS。通过使用 flex、flex-row 和 flex-col 等简单的实用程序,您可以轻松对齐和排列元素。 Tailwind Flex 非常适合希望简化布局创建同时保持对对齐、方向和间距的完全控制的开发人员 - 所...
    编程 发布于2024-11-07
  • ETL:从文本中提取人名
    ETL:从文本中提取人名
    假设我们想要抓取chicagomusiccompass.com。 如您所见,它有几张卡片,每张卡片代表一个事件。现在,让我们看看下一篇: 注意事件名称是: jazmin bean: the traumatic livelihood tour 所以现在的问题是:我们如何从文本中提取艺术家的名字? 作为...
    编程 发布于2024-11-07
  • 如何控制 C++ ostream 输出中的浮点精度?
    如何控制 C++ ostream 输出中的浮点精度?
    在 Ostream 输出中维护浮点精度在 C 中,在 ostream 运算中使用“
    编程 发布于2024-11-07
  • 如何保证PHP会话的安全销毁?
    如何保证PHP会话的安全销毁?
    确保销毁 PHP 会话尽管信息存在冲突,但仍有有效的方法可以安全地消除 PHP 会话。要实现此最终终止,遵循多步骤流程至关重要。会话终止的基本步骤删除会话数据:启动会话后与 session_start() 一起,使用 unset() 删除与特定会话变量关联的任何存储数据,例如 $_SESSION[&...
    编程 发布于2024-11-07
  • 为什么我的 MongoDB 文档在 Go 中使用 TTL 索引 5 秒后没有过期?
    为什么我的 MongoDB 文档在 Go 中使用 TTL 索引 5 秒后没有过期?
    在 Go 中使用 MongoDB 在指定的秒数后使文档过期使用 TTL 索引,MongoDB 允许您在指定的秒数后自动使文档过期期间。本文演示了如何使用官方 mongo-go-driver 在 Go 中实现此目的。按照 MongoDB 文档,代码显示了如何:创建带有 expireAfterSecon...
    编程 发布于2024-11-07
  • 使用 JetForms 简化表单管理:完整指南
    使用 JetForms 简化表单管理:完整指南
    在当今的数字环境中,管理表单提交很快就会变得不堪重负,特别是当您跨不同平台处理多个表单时。无论是网站上的简单联系表单还是产品的全面调查,手动维护表单提交都是一件麻烦事。这就是 JetForms 的用武之地——一个简化流程、节省您时间和精力的精简平台。 在本指南中,我将引导您了解如何开始使用 JetF...
    编程 发布于2024-11-07
  • 使用列表列表时如何修复 Tensorflow 中的“不支持的对象类型浮点”错误?
    使用列表列表时如何修复 Tensorflow 中的“不支持的对象类型浮点”错误?
    Tensorflow - ValueError:无法将 NumPy 数组转换为张量(不支持的对象类型 float)背景您正在尝试训练一个包含列表列表的模型,每个列表包含 1000 个浮点数,但遇到错误“无法将 NumPy 数组转换为张量(不支持的对象类型浮点)。”原因和解决方案 Tensorflow...
    编程 发布于2024-11-07

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3