0

0

javascript如何操作数组_有哪些常用的高阶函数?

夜晨

夜晨

发布时间:2026-01-04 21:19:02

|

625人浏览过

|

来源于php中文网

原创

javascript数组高阶函数需按目标精准选用:map用于一对一转换并返回新数组,filter返回满足条件的所有元素,find返回首个匹配项,some返回布尔值,reduce适用于复杂聚合但易出错,flat/flatmap/at简化嵌套与越界操作。

javascript如何操作数组_有哪些常用的高阶函数?

JavaScript 操作数组最常用、最实用的方式就是高阶函数,它们不修改原数组(多数情况下),语义清晰,链式调用自然。但别盲目套用——选错函数或忽略返回值类型,很容易导致 undefined、空数组或意外的嵌套结构。

map 用来「一对一」转换,别把它当 for 循环用

map 的核心是生成一个新数组,长度和原数组一致,每个元素由回调函数的返回值决定。它不是用来“遍历执行副作用”的——想发请求、改 DOM、写日志,请用 forEach

  • 如果回调没写 return,新数组里全是 undefined
  • map 对稀疏数组保留空位([1,,3].map(x => x * 2)[2, empty, 6]
  • 不能跳过元素:想条件映射?先 filtermap,或者在回调里用三元表达式兜底
const nums = [1, 2, 3];
const doubled = nums.map(n => n * 2); // [2, 4, 6]
const withIndex = nums.map((n, i) => `${i}:${n}`); // ['0:1', '1:2', '2:3']

filter + find + some 都做判断,但目的完全不同

filter 返回满足条件的**所有元素组成的新数组**;find 只返回**第一个匹配项**(找不到是 undefined);some 返回布尔值,适合提前退出的“是否存在”场景。

  • filter 不会短路,哪怕第一个就满足,它也会遍历全部
  • findfindIndex 是配对的:一个要值,一个要下标
  • someevery 性能更好,尤其处理大数组且预期早命中时
const users = [{id: 1, active: true}, {id: 2, active: false}, {id: 3, active: true}];
const actives = users.filter(u => u.active); // [{id:1,…}, {id:3,…}]
const firstActive = users.find(u => u.active); // {id: 1, active: true}
const hasInactive = users.some(u => !u.active); // true

reduce 是万能补丁,但别为简单逻辑硬套

reduce 能实现 mapfilter、求和、扁平化、分组……但它可读性差、易出错。小任务用专用函数更安全。

动态WEB网站中的PHP和MySQL:直观的QuickPro指南第2版
动态WEB网站中的PHP和MySQL:直观的QuickPro指南第2版

动态WEB网站中的PHP和MySQL详细反映实际程序的需求,仔细地探讨外部数据的验证(例如信用卡卡号的格式)、用户登录以及如何使用模板建立网页的标准外观。动态WEB网站中的PHP和MySQL的内容不仅仅是这些。书中还提到如何串联JavaScript与PHP让用户操作时更快、更方便。还有正确处理用户输入错误的方法,让网站看起来更专业。另外还引入大量来自PEAR外挂函数库的强大功能,对常用的、强大的包

下载

立即学习Java免费学习笔记(深入)”;

  • 必须显式提供初始值(acc),否则第一次调用时 acc 是第一个元素,cur 是第二个——容易索引错乱
  • 累加对象或数组时,别直接 push / assign 原对象,要返回新对象/数组(保持纯函数)
  • 扁平一层用 flat(),分组统计优先考虑 Object.groupBy(ES2024)或 reduce + ??=
const arr = [1, 2, 3, 4];
const sum = arr.reduce((acc, cur) => acc + cur, 0); // 10
const grouped = arr.reduce((acc, n) => {
  const key = n % 2 === 0 ? 'even' : 'odd';
  acc[key] = acc[key] || [];
  acc[key].push(n);
  return acc;
}, {}); // {odd: [1, 3], even: [2, 4]}

flat /flatMap / at 是现代数组操作的隐藏利器

这些方法在处理嵌套结构或越界访问时,比手写循环或 reduce 更简洁、更健壮。

  • flat(1) 只展开一层,flat(Infinity) 彻底打平——但注意性能,深层嵌套慎用
  • flatMap = map + flat(1),适合 map 出数组后立刻拍平的场景(比如提取多维数据中的字段)
  • at(-1) 安全取末尾,at(-2) 取倒数第二,不用再写 arr[arr.length - 1] 或担心 undefined
const matrix = [[1, 2], [3, 4], [5]];
const flattened = matrix.flat(); // [1, 2, 3, 4, 5]
const lengths = matrix.flatMap(row => row.length); // [2, 2, 1]
const last = [10, 20, 30].at(-1); // 30

真正难的不是记住函数名,而是每次写之前问一句:我到底要的是新数组、单个值、布尔结果,还是副作用?选错起点,后面全是补丁。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
php中foreach用法
php中foreach用法

本专题整合了php中foreach用法的相关介绍,阅读专题下面的文章了解更多详细教程。

266

2025.12.04

length函数用法
length函数用法

length函数用于返回指定字符串的字符数或字节数。可以用于计算字符串的长度,以便在查询和处理字符串数据时进行操作和判断。 需要注意的是length函数计算的是字符串的字符数,而不是字节数。对于多字节字符集,一个字符可能由多个字节组成。因此,length函数在计算字符串长度时会将多字节字符作为一个字符来计算。更多关于length函数的用法,大家可以阅读本专题下面的文章。

954

2023.09.19

golang map内存释放
golang map内存释放

本专题整合了golang map内存相关教程,阅读专题下面的文章了解更多相关内容。

77

2025.09.05

golang map相关教程
golang map相关教程

本专题整合了golang map相关教程,阅读专题下面的文章了解更多详细内容。

40

2025.11.16

golang map原理
golang map原理

本专题整合了golang map相关内容,阅读专题下面的文章了解更多详细内容。

67

2025.11.17

java判断map相关教程
java判断map相关教程

本专题整合了java判断map相关教程,阅读专题下面的文章了解更多详细内容。

47

2025.11.27

undefined是什么
undefined是什么

undefined是代表一个值或变量不存在或未定义的状态。它可以作为默认值来判断一个变量是否已经被赋值,也可以用于设置默认参数值。尽管在不同的编程语言中,undefined可能具有不同的含义和用法,但理解undefined的概念可以帮助我们更好地理解和编写程序。本专题为大家提供undefined相关的各种文章、以及下载和课程。

6468

2023.07.31

网页undefined是什么意思
网页undefined是什么意思

网页undefined是指页面出现了未知错误的意思,提示undefined一般是在开发网站的时候定义不正确或是转换不正确,或是找不到定义才会提示undefined未定义这个错误。想了解更多的相关内容,可以阅读本专题下面的文章。

3335

2024.08.14

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

3

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 6万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 3.4万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号