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

更新日期: 2021-06-23 阅读: 1.9k 标签: 数组

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


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.forEach()

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

如下:

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

输出结果如下:

文章索引 0 的标题为《如何在 Vue 的计算属性中传递参数》
文章索引 1 的标题为《Angular数据状态管理框架:NgRx/Store》
文章索引 2 的标题为《Angular管道PIPE介绍》
当需要简单地循环遍历数组的每个元素而不需要构建新数组时。


5. for...of

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

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

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


6. 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() ?**当需要确认数组的每一项都通过定义的条件时。


7. Array.some()

.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


8. Array.reduce()

.reduce() 方法接受一个回调函数作为其第一个参数,一个可选的初始值作为其第二个参数。如果没有提供初始值,则使用第一个数组元素作为值。回调函数提供一个累加器 accumulator 和 currentValue 参数,用于执行 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 ]
当需要通过操作其值将数组向下转换为单个值时,可以使用 .reduce() 方法


总结

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

原文来自:https://my.oschina.net/lav/blog/5087609


本文内容仅供个人学习、研究或参考使用,不构成任何形式的决策建议、专业指导或法律依据。未经授权,禁止任何单位或个人以商业售卖、虚假宣传、侵权传播等非学习研究目的使用本文内容。如需分享或转载,请保留原文来源信息,不得篡改、删减内容或侵犯相关权益。感谢您的理解与支持!

链接: https://fly63.com/article/detial/10465

相关推荐

indexOf的三种使用方法

indexOf() 方法可返回某个指定的字符串值在字符串中首次出现的位置。这里基本用法大家一般都清楚,一般在实际工作中常与数组的方法合用来对数组进行一些操作

关于Vue不能监听(watch)数组变化

vue无法监听数组变化的情况,但是数组在下面两种情况下无法监听:利用索引直接设置数组项时,例如arr[indexofitem]=newValue;修改数组的长度时,例如arr.length=newLength

JS计算两个数组的交集、差集、并集、补集(多种实现方式)

使用 ES5 语法来实现虽然会麻烦些,但兼容性最好,不用考虑浏览器 JavaScript 版本,使用 ES5 语法来实现虽然会麻烦些,但兼容性最好,不用考虑浏览器 JavaScript 版本。也不用引入其他第三方库。

js数组中改变元素的位置:互换,置顶,上移,下移

unshift() 方法可向数组的开头添加一个或更多元素,并返回新的长度。shift() 方法用于把数组的第一个元素从其中删除,并返回第一个元素的值。splice() 方法可删除从 index 处开始的零个或多个元素

js使用数组+循环+条件实现数字转换为汉字的简单方法。

单个数字转汉字的解决方法:利用数组存储0-9的汉字、 ary.length和str.length不用多说,这是指ary数组和str字符串的长度。这里我们需要注意的是str.charAt(j)和ary[i],分别指在str这个字符串中索引为j的元素,在ary中索引为i的元素。

Js遍历数组时注意 Empty Item 的影响

这两天碰到个问题:从日志中发现一些来自 iOS 10.3 的报错「Cannot read property \\\'xxx\\\' of undefined」,定位到代码的报错位置,发现是遍历某数组时产生的报错,该数组的元素应该全都是 Object,但实际上出现了异常的元素

JS数组扁平化(flat)方法总结

需求:多维数组=>一维数组 ;flat和flatMap方法为ES2019(ES10)方法,目前还未在所有浏览器完全兼容。第四种处理:用 reduce 实现数组的 flat 方法

数组、字符串去重

今天说的数组和字符串去重呢,主要用到es6新的数据结构 Set,它类似于数组,但是成员的值都是唯一的,没有重复的值,所以活用Set来进行数组和字符串的去重。

Js数组中所有方法(超详细)

concat()把元素衔接到数组中。 every() 方法使用指定函数检测数组中的所有元素:filter()返回满足断言函数的数组元素。forEach()为数组的每一个元素调用指定函数。

[译]async-await 数组循环的几个坑

在 Javascript 循环中使用 async/ await 循环遍历数组似乎很简单,但是在将两者结合使用时需要注意一些非直观的行为。让我们看看三个不同的例子,看看你应该注意什么,以及哪个循环最适合特定用例。

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!