Day 1:手写数组方法 - 掌握数据处理的基石

🎯今日学习目标

  • 理解数组方法的核心设计思想

  • 掌握forEachmapfilterreduce、find、some、every、flat、flatMap的实现

  • 学会处理边界情况和异常

📚 前情:首先明白什么是数组?数组有哪些属性和特性?

  1. 数组是有序(顺序固定)的数据集合,通过数字索引来访问元素(从0开始);
  2. 核心属性:length、数字索引
  3. 特性:可以存储任意类型、长度自动更新
  4. js内置了很多常用的方法在数组的原型上

【第一步】 分析原生行为

javascript 复制代码
const arr = [1, 2, 3, 4, 5];

// forEach - 遍历执行,直接修改原数组
arr.forEach(el => console.log(el)); // 依次输出1 2 3 4 5

// map - 遍历执行,返回一个新数组
arr.map(el => el + 1); // [2, 3, 4, 5, 6]

// filter - 筛选出符合条件的元素,返回新数组
arr.filter(el => el > 3); // [4, 5]

// reduce - 累计计算并返回结果
arr.reduce((acc, cur) => acc + cur); // 15

// find - 找到第一个符合条件的元素,返回该元素
arr.find(el => el*2 === 6); // 3

// some - 检查至少有一个符合的元素,返回 true 或 false
arr.some(el => el === 5); // true

// every - 检查所有元素都符合,返回 true 或 false
arr.every(el => typeof(el) === 'number'); // true

// flat - 扁平化数组--可以传扁平化的层次(默认是1),返回一个新数组
[[arr]].flat(2); // [1, 2, 3, 4, 5]

// flatMap - 先map再执行flat(1),返回一个新数组
arr.flatMap(el => [el, el + 1]); // [1, 2, 2, 3, 3, 4, 4, 5, 5, 6]

【第二步】 注意边界条件

  1. 空数组
  2. 稀疏数组 ??包含空位的数组,空位没有索引但是会占用数组的长度
  3. 考虑其他数据类型(undefined、null、类对象)
  4. 错误捕获
  5. 注意this的流转

【第三步】 搭建基础框架

  1. 制定合理的方法名
  2. 确认每个方法的输入和输出

【第四步】 具体实现和测试

1. forEach

javascript 复制代码
1
相关推荐
Highcharts.js5 分钟前
缺失数据可视化图表开发实战|Highcharts创建人员出生统计面积图表示例
开发语言·前端·javascript·信息可视化·highcharts·图表开发
LaughingZhu7 小时前
Product Hunt 每日热榜 | 2026-05-21
前端·人工智能·经验分享·chatgpt·html
怕浪猫7 小时前
Electron 开发实战(一):从零入门核心基础与环境搭建
前端·electron·ai编程
小鹏linux8 小时前
Ubuntu 22.04 部署开源免费具有精美现代web页面的Casdoor账号管理系统
linux·前端·ubuntu·开源·堡垒机
前端若水8 小时前
会话管理:创建、切换、删除对话历史
前端·人工智能·python·react.js
Bigger9 小时前
mini-cc:一个轻量级 AI 编程助手的诞生
前端·ai编程·claude
涵涵(互关)9 小时前
Naive-ui树型选择器只显示根节点
前端·ui·vue
BY组态9 小时前
Ricon组态系统最佳实践:从零开始构建物联网监控平台
前端·物联网·iot·web组态·组态
BY组态9 小时前
Ricon组态系统vs传统组态软件:为什么选择新一代Web组态平台
前端·物联网·iot·web组态·组态
SoaringHeart9 小时前
Flutter进阶:OverlayEntry 插入图层管理器 NOverlayZIndexManager
前端·flutter