当前位置: 首页 > news >正文

js中map,filter,find,foreach的用法介绍

js中map,filter,find,foreach的用法介绍

在 JavaScript 中,数组提供了一些常用的迭代方法,如 mapfilterfindforEach,这些方法允许你对数组中的每个元素进行操作,下面是它们的用法和区别。

1. map()

map() 方法用于遍历数组中的每一个元素,并将每个元素经过操作后的结果返回为一个新的数组,不改变原数组

语法:
const newArray = array.map((element, index, array) => {// return 操作后的新值
});
示例:
const numbers = [1, 2, 3, 4];
const doubled = numbers.map(num => num * 2);console.log(doubled); // 输出: [2, 4, 6, 8]
console.log(numbers); // 原数组: [1, 2, 3, 4]

2. filter()

filter() 方法用于过滤数组中的元素,并返回符合条件的元素组成的新数组不会改变原数组

语法:
const filteredArray = array.filter((element, index, array) => {// return 一个布尔值 (true 或 false)
});
示例:
const numbers = [1, 2, 3, 4, 5];
const evenNumbers = numbers.filter(num => num % 2 === 0);console.log(evenNumbers); // 输出: [2, 4]
console.log(numbers);     // 原数组: [1, 2, 3, 4, 5]

3. find()

find() 方法用于查找数组中第一个符合条件的元素,并返回该元素。如果没有找到符合条件的元素,则返回 undefined不会改变原数组

语法:
const foundElement = array.find((element, index, array) => {// return 一个布尔值 (true 或 false)
});
示例:
const users = [{ id: 1, name: 'John' },{ id: 2, name: 'Jane' },{ id: 3, name: 'Jack' }
];const user = users.find(user => user.id === 2);console.log(user); // 输出: { id: 2, name: 'Jane' }

4. forEach()

forEach() 方法用于遍历数组中的每一个元素并执行给定的操作,不会返回任何值,也不会改变原数组。它的作用只是执行循环操作。

语法:
array.forEach((element, index, array) => {// 执行某些操作
});
示例:
const numbers = [1, 2, 3, 4];
numbers.forEach(num => console.log(num * 2));// 输出: 
// 2
// 4
// 6
// 8

主要区别:

  • map():对每个元素执行操作并返回一个新数组。
  • filter():对每个元素进行条件判断,返回符合条件的元素组成的新数组。
  • find():查找并返回第一个符合条件的元素,返回单个元素。
  • forEach():遍历数组并对每个元素执行操作,但不返回值(常用于执行副作用操作,如打印输出)。

小结:

  • map()filter() 都返回新的数组。
  • find() 返回单个元素或 undefined
  • forEach() 不返回任何值,主要用于循环操作。

在这里插入图片描述

http://www.lryc.cn/news/461923.html

相关文章:

  • Linux 重置 root 密码
  • 【含开题报告+文档+PPT+源码】基于SpringBoot+Vue的停车场管理系统
  • 博睿数据首届“观测先锋 · 2024 可观测平台创新应用案例大赛”现已启动!
  • 笔记:SOME/IP-SD报文中的TTL
  • 9.存储过程安全性博客大纲(9/10)
  • android 打包成aar
  • 服务器和中转机在网络安全方面
  • 解决“无法从 System.String 强制转换或转换为 Class 对象”错误
  • Git:LF will be replaced by CRLF、pytest PermissionError以及Git应用中的一些问题解决及一些使用技巧
  • 云原生之运维监控实践-使用taosKeeper与TDinsight实现对TDengine服务的监测告警
  • 前端js,vue系统使用iframe嵌入第三方系统的父子系统的通信
  • 树莓派刷入OpenWrt后扩容overlay的方法
  • 【JS】Node.js读取execle表格中的数据
  • 怎么为pdf文件设置密码?几种PDF文件设置密码的方法推荐
  • Rust : FnOnce、线程池与多策略执行
  • 一个汉字占几个字节、JS中如何获得一个字符串占用多少字节?
  • CommonJS 和 ES modules
  • 计算机网络——CDN
  • 大数据治理:挑战与策略
  • 屋面通风器安装方案及流程
  • ComfyUI一键更换服装:IP-Adapter V2 + FaceDetailer(DeepFashion)
  • AWS账号与亚马逊账号的关系解析
  • Java八大基本数据类型详解
  • ChatGPT的终极指南概要
  • Android应用性能优化的方法
  • 『网络游戏』客户端发送消息到服务器【17】
  • 【系统架构设计师】专题:数据库系统考点梳理
  • Java传递对象是值传递还是引用传递?
  • 解锁C++多态的魔力:灵活与高效的编码艺术(上)
  • k8s系列-Rancher 上操作的k8s容器网络配置总结