JS 数组中的forEach、map、filter、find四个方法的使用方法
发布时间:2025-05-19 19:35:41 发布人:远客网络
一、JS 数组中的forEach、map、filter、find四个方法的使用方法
1、JavaScript数组中,四个强大且实用的高阶函数——forEach、map、filter和find,各自具有独特的功能。forEach用于逐个遍历数组元素,执行给定的函数,但不返回值,主要用作副作用操作。例如:
2、map方法则用于创建新数组,每个元素是原数组元素经过函数处理后的结果。例如:
3、let doubled= numbers.map((num)=> num* 2);
4、console.log(doubled);// [2, 4, 6, 8, 10]
5、filter方法则筛选出数组中符合条件的元素,生成新数组。例如:
6、let even= arr.filter((num)=> num% 2=== 0);
7、find方法则在数组中查找第一个满足给定条件的元素,返回该元素的值,否则返回undefined。例如:
8、let obj={ name:'John', age: 30};
9、let result= obj.find((value)=> value.age> 25);
10、console.log(result);//{ age: 30}
11、总的来说,这四个函数在处理数组时,分别提供了遍历、变换、筛选和查找的功能,极大地简化了数组操作的复杂性。熟练掌握它们,将有助于提升你的JavaScript编程效率。
二、js页面中for each循环里如何添加索引
1、js的for里面的变量就是下标索引。
2、varperson={fname:"John",lname:"Doe",age:25};
3、}
补充:你说的是foreach,那就是定义遍历函数时有个参数是索引。
4、补充:你说的是foreach,那就是定义遍历函数时有个参数是索引。
5、array.forEach(callback[, thisArg])
6、在数组每一项上执行的函数,接收三个参数:
7、当前项(指遍历时正在被处理那个数组项)的值。
8、可选参数。用来当作callback函数内this的值的对象。
9、参考:
三、详解JS中常见的5 种 for 循环
for循环在平时开发中使用频率最高的,前后端数据交互时,常见的数据类型就是数组和对象,处理对象和数组时经常使用到 for遍历,因此需要彻底搞懂这 5种 for循环。它们分别为:
for循环是出现最早,也是应用最普遍的一个遍历,能够满足绝大多数的遍历。可以遍历数组、对象、字符串,示例:
for... in是在 ES5中新增的,以任意顺序迭代一个对象的除Symbol以外的可枚举属性,包括继承的可枚举属性。
for... of语句在可迭代对象(包括 Array、Map、Set、String、TypedArray、arguments对象等等)上创建一个迭代循环,调用自定义迭代钩子,并为每个不同属性的值执行语句。
创建一个循环,该循环遍历异步可迭代对象以及同步可迭代对象,包括内置的 String、Array,类数组对象(arguments或 nodeList),TypedArray, Map, Set和用户定义的异步/同步迭代器。
它使用对象的每个不同属性的值调用要执行的语句来调用自定义迭代钩子。
类似于 await运算符一样,该语句只能在一个async function内部使用
forEach是ES5版本发布的,按升序为数组中含有效值的每一项执行一次回调函数,那些已删除或者未初始化的项将被跳过(例如在稀疏数组上),一般认为是普通for循环的加强版。
遍历时可以返回一个新数组,新数组的结果是原数组中每个元素都调用一次提供的函数后返回的值。
for循环是最早最原始的循环遍历语句,for内部定义一个变量,按照条件进行循环遍历,通常是数组的长度,当超过长度时就停止循环,一般遍历的都是数组或类数组。
遍历对象时,由于对象没有长度,所以使用 Object.keys()获取对象的所有属性,以数组形式返回。
for/ in主要是用来遍历对象上的可枚举属性,包括原型对象上的属性,按任意顺序进行遍历,遍历对象时获取到的是属性的键值,遍历的是数组,数组的下标当做键值。
for/ of用于遍历可迭代对象的数据,包括 Array、Map、Set、String、TypedArray、arguments对象等等。
for await...of用于遍历异步可迭代对象,该语句只能在一个async function内部使用。
forEach是 for的加升级版,使用更简单,携带参数更多,但本质还是数组的循环,每个元素都执行一次回调,不会改变原数组。
map是给原数组每个元素都执行一次回调,返回一个新数组,不会改变原数组。
forEach、map不支持跳出循环,其他不支持。
for await... of能够支持异步操作,其他的不支持。
对于纯对象的遍历, for... in枚举更方便。
对于数组遍历,如果不需要索引,可以直接使用 for...of获取值,还可支持 break或 return;如果还需要索引,使用 forEach更适合,但不支持 return。
如果是一个数组映射成另一个数组,使用 map最合适。
在测试环境、测试数据条件一致的情况下,性能排序为:
for> for of> forEach> map> for in。
for因为没有额外的函数调用和上下文,所以性能是最快的。
for... of具有 iterator接口的数据结构,可以使用它来迭代成员,直接读取键值。
forEach是 for的语法糖,还有许多的参数和上下文,因此会慢一些。
map因为它返回的是一个等长的全新数组,数组创建和赋值产生的性能开销较大。
for...in性能最差,因为需要列举对象的所有属性,有转化过程,开销比较大。
在项目开发中,我们应该根据实际需求,去选择一个合适的 for遍历。以下是一些使用建议:
如果需要把数据映射成另外一个数组,如变成对应布尔值,推荐使用 map,不会修改原数组,使用语法简单。
数组遍历时,可以使用 for、forEach或 for...of。
遍历的是纯对象时,推荐使用 for... in。
如果是需要对迭代器遍历,推荐使用 for... of。
如果是在数组中筛选符合条件的数组,使用 fillter。