JavaScript 数组操作必须熟练运用的10个方法

简介: JavaScript 提供了大量不同的处理数组的方法,这里花几分钟时间介绍 10 个项目中可以用到的数组方法。

JavaScript 提供了大量不同的处理数组的方法,这里花几分钟时间介绍 10 个项目中可以用到的数组方法。

1. Array.map()

使用.map() 方法,可以创建一个基于原始数组的修订版数组。.map() 方法接受一个函数,该函数遍历数组中的所有项并进行相应的修改。

当需要更新数组中的所有项并将其存储到一个新数组中时,.map() 方法就可以派上用场了。

例如有一个文章列表的数组,如下:

const articles = [
    {
        article_id: "6976209276364652558",
        title: "如何在 Vue 的计算属性中传递参数",
        views: 1258,
    },
    {
        article_id: "6976113133358153736",
        title: "Angular数据状态管理框架:NgRx/Store",
        views: 2258,
    },
    {
        article_id: "6975722363241365534",
        title: "Angular管道PIPE介绍",
        views: 1568,
    },
];

现在基于上面文章列表数组,获取所有 title 组成的数组,如下:

const arrayTitles = articles.map((item) => item.title);
console.log(arrayTitles);

输出的结果如下:

[
  '如何在 Vue 的计算属性中传递参数',
  'Angular数据状态管理框架:NgRx/Store',
  'Angular管道PIPE介绍'
]

当然,只要是数组都可以使用 .map() ,接下来就基于上面标题数组,增加作者信息,如下:

const arrayTitlesWithAuthor = arrayTitles.map(
    (title) => `《${title}》作者:天行无忌`
);
console.log(arrayTitlesWithAuthor);

输出结果如下:

[
  '《如何在 Vue 的计算属性中传递参数》作者:天行无忌',
  '《Angular数据状态管理框架:NgRx/Store》作者:天行无忌',
  '《Angular管道PIPE介绍》作者:天行无忌'
]

.map() 方法是一个用来创建新数组、修改其内容并保持原始数组不变的通用方法。当出现需要修改现有数组的内容并将结果存储为新变量的时候就可以用。

2. Array.filter()

从方法名称可以很容易知道其用途,没错用于过滤数组元素。

filter()方法根据特定条件获取数组中的元素,像 .map() 方法一样,它将返回一个新数组,并保持原始数组不变。

基于上面的 articles 数组,分别获取 views 小于 2000 的和大于 2000 的文章列表:

const lessArticles = articles.filter((item) => item.views < 2000);
const muchArticles = articles.filter((item) => item.views > 2000);
console.log(lessArticles);
console.log("\r\n==========================================\r\n");
console.log(muchArticles);

输出的结果如下:

[
  {
    article_id: '6976209276364652558',
    title: '如何在 Vue 的计算属性中传递参数',
    views: 1258
  },
  {
    article_id: '6975722363241365534',
    title: 'Angular管道PIPE介绍',
    views: 1568
  }
]
==========================================
[
  {
    article_id: '6976113133358153736',
    title: 'Angular数据状态管理框架:NgRx/Store',
    views: 2258
  }
]

当需要从数组中删除不符合特定条件的元素时,可以使用 .filter()

3. Array.find()

.find() 方法看起来很像前面介绍的.filter()方法。跟 .filter() 方法一样,将匹配的条件的元素返回,区别在于,.find() 将只返回与提供的条件匹配的第一个元素,不是数组。

将上面的 .filter() 方法改为 .find(),如下:

const lessArticle = articles.find((item) => item.views < 2000);
const muchArticle = articles.find((item) => item.views > 2000);
console.log(lessArticle);
console.log("\r\n==========================================\r\n");
console.log(muchArticle);

输出结果如下:

{
  article_id: '6976209276364652558',
  title: '如何在 Vue 的计算属性中传递参数',
  views: 1258
}
==========================================
{
  article_id: '6976113133358153736',
  title: 'Angular数据状态管理框架:NgRx/Store',
  views: 2258
}

**什么时候使用 Array.find() ?**当需要获取数组通过定义条件的第一个元素时。

4. Array.findIndex()

.findIndex() 方法在名称上跟 .find()  前半部分一样,其实现的功能和.find() 一样,其区别在于返回值不一样,只返回与提供的条件匹配的第一个元素的索引值。

const lessArticle = articles.findIndex((item) => item.views < 2000);
const muchArticle = articles.findIndex((item) => item.views > 2000);
console.log(lessArticle); // 0
console.log(muchArticle); // 1

**什么时候使用 Array.findIndex() ?**当需要获取数组通过定义条件的第一个元素所在数组中的索引值时。

5. Array.forEach()

.forEach() 方法的工作方式很像常规的 for 循环,遍历一个数组并在每个元素上执行一个函数。 .forEach() 的第一个参数是回调函数,它包含循环数组的当前值和索引。

如下:

articles.forEach((item, index) => {
    console.log(`文章索引 ${index} 的标题为《${item.title}》`);
});

输出结果如下:

文章索引 0 的标题为《如何在 Vue 的计算属性中传递参数》
文章索引 1 的标题为《Angular数据状态管理框架:NgRx/Store》
文章索引 2 的标题为《Angular管道PIPE介绍》

当需要简单地循环遍历数组的每个元素而不需要构建新数组时。

6. for...of

for...of 是es6推出的迭代器,号称最简洁,可以是用 breakcontinuereturn 终止循环。跟 .forEach() 不同的是,不提供数组索引。跟 for 语句相比代码少得多,更简洁。

下面代码遍历输出数组,如下:

for (const item of articles) {
    console.log(item);
}

7. for...in

这个方法跟上面的for...of 语法上看起来相似,for...of 是对值的遍历,for...in 是对 key/index 的遍历。for...in  应用于数组则 key 对应的就是数组的索引值,应用于对象则 key 对应键值。

来看代码执行效果,先应用于数组,如下:

for (const key in articles) {
    console.log(key);
}

上面代码输出的是数组的索引值:0、1、2,下面应用于数组第一个对象,如下:

for (const key in articles[0]) {
    console.log(key);
}

输出的就是:article_idtitleviews

在实际开发中不提倡使用 for...in,如果需要遍历对象属性,推荐使用 Object.keys

8. Array.every()

.every() 方法将检查数组中的每个元素是否都通过提供的条件,如果数组中的所有元素都通过条件,则将返回 true ,如果没有,将返回 false

例如,检查 articles 数组所有的文章 views 都超过 1000,如下:

const isMoreThan1000 = articles.every((item) => item.views > 1000);
console.log(isMoreThan1000);  // true

检查 articles 数组所有的文章 views 都超过 2000,如下:

const isMoreThan2000 = articles.every((item) => item.views > 2000);
console.log(isMoreThan2000); // false

**什么时候使用 Array.every() ?**当需要确认数组的每一项都通过定义的条件时。

9. Array.some()

.some() 方法和 .every() 方法类似,但验证的结果是相反的,如果数组中的所有元素只要有一个通过条件,则将返回 true ,如果所有的元素都不通过条件,将返回 false

.some() 方法和 .every() 方法在文章《7 个你应该掌握的 JavaScript 编码技巧》中介绍了如何实现逻辑 andor

例如,检查 articles 数组所有的文章 views 是否有 views 超过 2000 的文章,如下:

const isMore2000 = articles.some((item) => item.views > 2000);
console.log(isMore2000); // true

检查 articles 数组所有的文章 是否有 views 超过 3000 的文章,如下:

const isMore3000 = articles.some((item) => item.views > 3000);
console.log(isMore3000);  // false

10. Array.reduce()

前面专门为此方法分享过一篇文章《javascript数组之includes、reduce》。

.reduce() 方法接受一个回调函数作为其第一个参数,一个可选的初始值作为其第二个参数。如果没有提供初始值,则使用第一个数组元素作为值。回调函数提供一个累加器 accumulatorcurrentValue 参数,用于执行 reduce 计算。

这里就简单举个例子,对 articles 数组的 views 进行累加求和:

const sumViews = articles.reduce(
    (accumulator, current) => accumulator + current.views,
    0
);
console.log(sumViews); // 5084

使用 .reduce() 方法可以用于展平一个数组,当然已经有很多方法可以做到这一点,这就是其中的方法之一。

const flattened = [
    [0, 1],
    [2, 3],
    [4, 5],
].reduce((accumulator, current) => accumulator.concat(current), []);
console.log(flattened); // [ 0, 1, 2, 3, 4, 5 ]

总结

JavaScript 提供了大量不同的处理数组的方法,本文介绍的 10 个在日常项目开发中使用频率比较高的数组处理方法,可以作为基础知识收藏。


相关文章
|
28天前
|
JavaScript 前端开发 程序员
前端原生Js批量修改页面元素属性的2个方法
原生 Js 的 getElementsByClassName 和 querySelectorAll 都能获取批量的页面元素,但是它们之间有些细微的差别,稍不注意,就很容易弄错!
|
1月前
|
Web App开发 JavaScript 前端开发
如何确保 Math 对象的方法在不同的 JavaScript 环境中具有一致的精度?
【10月更文挑战第29天】通过遵循标准和最佳实践、采用固定精度计算、进行全面的测试与验证、避免隐式类型转换以及持续关注和更新等方法,可以在很大程度上确保Math对象的方法在不同的JavaScript环境中具有一致的精度,从而提高代码的可靠性和可移植性。
|
2月前
|
缓存 监控 前端开发
JavaScript 实现大文件上传的方法
【10月更文挑战第17天】通过以上步骤和方法,我们可以实现较为可靠和高效的大文件上传功能。当然,具体的实现方式还需要根据实际的应用场景和服务器要求进行调整和优化。
|
26天前
|
监控 JavaScript Java
Node.js中内存泄漏的检测方法
检测内存泄漏需要综合运用多种方法,并结合实际的应用场景和代码特点进行分析。及时发现和解决内存泄漏问题,可以提高应用的稳定性和性能,避免潜在的风险和故障。同时,不断学习和掌握内存管理的知识,也是有效预防内存泄漏的重要途径。
121 52
|
1月前
|
JavaScript 前端开发 索引
js中DOM的基础方法
【10月更文挑战第31天】这些DOM基础方法是操作网页文档结构和实现交互效果的重要工具,通过它们可以动态地改变页面的内容、样式和行为,为用户提供丰富的交互体验。
|
1月前
|
缓存 JavaScript UED
js中BOM中的方法
【10月更文挑战第31天】
|
27天前
|
缓存 JavaScript 前端开发
JavaScript 与 DOM 交互的基础及进阶技巧,涵盖 DOM 获取、修改、创建、删除元素的方法,事件处理,性能优化及与其他前端技术的结合,助你构建动态交互的网页应用
本文深入讲解了 JavaScript 与 DOM 交互的基础及进阶技巧,涵盖 DOM 获取、修改、创建、删除元素的方法,事件处理,性能优化及与其他前端技术的结合,助你构建动态交互的网页应用。
40 5
|
28天前
|
JavaScript 前端开发
js中的bind,call,apply方法的区别以及用法
JavaScript中,`bind`、`call`和`apply`均可改变函数的`this`指向并传递参数。其中,`bind`返回一个新函数,不立即执行;`call`和`apply`则立即执行,且`apply`的参数以数组形式传递。三者在改变`this`指向及传参上功能相似,但在执行时机和参数传递方式上有所区别。
26 1
|
1月前
|
JavaScript 前端开发
.js方法参数argument
【10月更文挑战第26天】`arguments` 对象为JavaScript函数提供了一种灵活处理参数的方式,能够满足各种不同的参数传递和处理需求,在实际开发中具有广泛的应用价值。
39 7
|
1月前
|
JavaScript 前端开发 图形学
JavaScript 中 Math 对象常用方法
【10月更文挑战第29天】JavaScript中的Math对象提供了丰富多样的数学方法,涵盖了基本数学运算、幂运算、开方、随机数生成、极值获取以及三角函数等多个方面,为各种数学相关的计算和处理提供了强大的支持,是JavaScript编程中不可或缺的一部分。