使用.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()
方法是一个用来创建新数组、修改其内容并保持原始数组不变的通用方法。当出现需要修改现有数组的内容并将结果存储为新变量的时候就可以用。
从方法名称可以很容易知道其用途,没错用于过滤数组元素。
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()
。
.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() ?**当需要获取数组通过定义条件的第一个元素时。
.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() ?**当需要获取数组通过定义条件的第一个元素所在数组中的索引值时。
.forEach()
方法的工作方式很像常规的 for
循环,遍历一个数组并在每个元素上执行一个函数。.forEach()
的第一个参数是回调函数,它包含循环数组的当前值和索引。
如下:
articles.forEach((item, index) => {
console.log(`文章索引 ${index} 的标题为《${item.title}》`);
});
输出结果如下:
文章索引 0 的标题为《如何在 Vue 的计算属性中传递参数》
文章索引 1 的标题为《Angular数据状态管理框架:NgRx/Store》
文章索引 2 的标题为《Angular管道PIPE介绍》
当需要简单地循环遍历数组的每个元素而不需要构建新数组时。
for...of
是es6推出的迭代器,号称最简洁,可以是用 break
,continue
和 return
终止循环。跟 .forEach()
不同的是,不提供数组索引。跟 for
语句相比代码少得多,更简洁。
下面代码遍历输出数组,如下:
for (const item of articles) {
console.log(item);
}
这个方法跟上面的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_id
、title
、views
。
在实际开发中不提倡使用
for...in
,如果需要遍历对象属性,推荐使用Object.keys
。
.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() ?**当需要确认数组的每一项都通过定义的条件时。
.some()
方法和 .every()
方法类似,但验证的结果是相反的,如果数组中的所有元素只要有一个通过条件,则将返回 true
,如果所有的元素都不通过条件,将返回 false
。
例如,检查 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
数组的 reduce 方法是一种函数式编程中常用的高阶函数,它可以用来对数组中的元素进行迭代计算,并返回一个累积结果。
reduce 方法的基本语法如下:
array.reduce(callback[, initialValue])
其中,第一个参数 callback
是一个回调函数,用于对数组元素进行操作。该回调函数接受四个参数:
accumulator
:累积器,用于存放每次计算的结果,如果没有传入 initialValue
,则它的初始值为数组的第一个元素;currentValue
:当前值,即当前正在被操作的元素;currentIndex
:当前值的索引;array
:数组本身。为了更好地理解 reduce 方法,下面我们来看几个简单的示例:
1.求和
const numbers = [1, 2, 3, 4, 5]
const sum = numbers.reduce((accumulator, currentValue) => accumulator + currentValue)
console.log(sum) // 15
2.求数组的最大值
const numbers = [1, 2, 3, 4, 5]
const max = numbers.reduce((accumulator, currentValue) => {
return accumulator > currentValue ? accumulator : currentValue
})
console.log(max) // 5
3.将数组中的字符串连接成一个大字符串
const strings = ['hello', 'world', 'from', 'ChatAi']
const text = strings.reduce((accumulator, currentValue) => accumulator + currentValue)
console.log(text) // "helloworldfromChatAi"
以上是 reduce 方法常见的使用场景。需要注意的是:
callback
中必须返回一个值,以供累积运算;initialValue
参数,则累积器 accumulator
的初始值取数组的第一项;reduce
方法本身不会修改原数组,所以它是一个纯函数,对于不可变对象的操作非常适用;reduce
方法可以使用二次累积的方式,简单地实现很多高阶函数的功能。当需要通过操作其值将数组向下转换为单个值时,可以使用
.reduce()
方法
JavaScript 提供了大量不同的处理数组的方法,本文介绍的10个在日常项目开发中使用频率比较高的数组处理方法,可以作为基础知识收藏。