map()简介
map() 方法创建一个新数组,其中填充了对调用数组中每个元素调用所提供函数的结果。它是一种函数式编程技术,允许您将数组的每个元素转换为新元素,从而生成新数组而不修改原始数组。
语法
let newArray = array.map(function callback(currentValue, index, array) { // Return element for newArray }, thisArg);
或者,使用箭头函数:
let newArray = array.map((currentValue, index, array) => { // Return element for newArray });
参数
-
callback:生成新数组元素的函数,采用三个参数:
- currentValue:当前正在处理的元素。
- index (可选):当前元素的索引。
- 数组 (可选):调用了数组映射。
- thisArg (可选):执行回调时用作 this 的值。
返回值
一个新数组,每个元素都是回调函数的结果。
map() 的工作原理
- 不变性:map() 不会修改原始数组。
- 逐元素转换:将回调函数应用于每个元素。
- 返回一个新数组:将结果收集到一个新数组中。
示例
a.映射数字
示例:将数组中的每个数字乘以 2。
const numbers = [1, 2, 3, 4, 5]; const doubled = numbers.map(number => number * 2); console.log(doubled); // Output: [2, 4, 6, 8, 10]
b.变换字符串
示例:将字符串数组转换为大写。
const fruits = ['apple', 'banana', 'cherry']; const upperFruits = fruits.map(fruit => fruit.toUpperCase()); console.log(upperFruits); // Output: ['APPLE', 'BANANA', 'CHERRY']
c.提取对象属性
示例:从对象数组中提取特定属性。
const users = [ { id: 1, name: 'Alice' }, { id: 2, name: 'Bob' }, ]; const names = users.map(user => user.name); console.log(names); // Output: ['Alice', 'Bob']
d.映射对象数组
示例:转换数组中的每个对象。
const products = [ { productId: 1, price: 100 }, { productId: 2, price: 200 }, ]; const discountedProducts = products.map(product => ({ ...product, price: product.price * 0.9, })); console.log(discountedProducts); // Output: // [ // { productId: 1, price: 90 }, // { productId: 2, price: 180 }, // ]
map() 和 forEach() 之间的区别
-
地图():
- 返回一个新数组。
- 当您想要转换每个元素并收集结果时使用。
-
forEach():
- 返回未定义。
- 当您想要执行副作用(例如,记录日志、修改外部变量)并且不需要新数组时使用。
forEach() 示例:
let newArray = array.map(function callback(currentValue, index, array) { // Return element for newArray }, thisArg);
将 map() 与箭头函数结合使用
箭头函数提供了编写回调函数的简洁语法。
示例:
let newArray = array.map((currentValue, index, array) => { // Return element for newArray });
TypeScript 中的 map()
TypeScript 为 JavaScript 添加了静态类型,这有助于在编译时捕获错误。
a.输入注释
您可以指定数组中元素的类型和返回类型。
示例:
const numbers = [1, 2, 3, 4, 5]; const doubled = numbers.map(number => number * 2); console.log(doubled); // Output: [2, 4, 6, 8, 10]
b.通用类型
您可以定义通用函数来处理任何类型。
示例:
const fruits = ['apple', 'banana', 'cherry']; const upperFruits = fruits.map(fruit => fruit.toUpperCase()); console.log(upperFruits); // Output: ['APPLE', 'BANANA', 'CHERRY']
常见用例
- 转换数据:将数据从一种形式转换为另一种形式。
- 提取值:从对象中提取特定字段。
- 组合数据:根据现有数据创建新数组。
- 计算:对每个元素执行计算。
高级主题
a.将 map() 与其他数组方法链接
你可以将map()与其他数组方法链接起来,如filter()、reduce()等
示例:
const users = [ { id: 1, name: 'Alice' }, { id: 2, name: 'Bob' }, ]; const names = users.map(user => user.name); console.log(names); // Output: ['Alice', 'Bob']
b.处理异步操作
map() 不处理回调内的异步操作。如果需要执行异步操作,请考虑使用 Promise.all() 和 map()。
示例:
const products = [ { productId: 1, price: 100 }, { productId: 2, price: 200 }, ]; const discountedProducts = products.map(product => ({ ...product, price: product.price * 0.9, })); console.log(discountedProducts); // Output: // [ // { productId: 1, price: 90 }, // { productId: 2, price: 180 }, // ]
最佳实践
- 不要使用 map() 产生副作用:如果不需要新数组,请使用 forEach()。
- 避免修改原始数组:map() 不应改变原始数组或其元素。
- 返回值:确保你的回调函数返回一个值;否则,新数组将包含未定义的元素。
- 使用箭头函数来保持简洁:它们使您的代码更短且更具可读性。
结论
理解 map() 函数对于 JavaScript 和 TypeScript 中的有效数组操作至关重要。这是一种多功能方法,可让您干净高效地转换数据。记住map():
- 创建一个新数组。
- 对每个元素应用一个函数。
- 不修改原始数组。
通过掌握map(),您将编写更简洁、更实用的代码,从而获得更好的可维护性和可读性。
感谢您的阅读。如果你喜欢这个内容,请随时请我喝杯咖啡:
https://buymeacoffee.com/kellyblaire
以上是理解 JavaScript 数组 map() 方法的详细内容。更多信息请关注PHP中文网其他相关文章!

JavaScript字符串替换方法详解及常见问题解答 本文将探讨两种在JavaScript中替换字符串字符的方法:在JavaScript代码内部替换和在网页HTML内部替换。 在JavaScript代码内部替换字符串 最直接的方法是使用replace()方法: str = str.replace("find","replace"); 该方法仅替换第一个匹配项。要替换所有匹配项,需使用正则表达式并添加全局标志g: str = str.replace(/fi

因此,在这里,您准备好了解所有称为Ajax的东西。但是,到底是什么? AJAX一词是指用于创建动态,交互式Web内容的一系列宽松的技术。 Ajax一词,最初由Jesse J创造

10款趣味横生的jQuery游戏插件,让您的网站更具吸引力,提升用户粘性!虽然Flash仍然是开发休闲网页游戏的最佳软件,但jQuery也能创造出令人惊喜的效果,虽然无法与纯动作Flash游戏媲美,但在某些情况下,您也能在浏览器中获得意想不到的乐趣。 jQuery井字棋游戏 游戏编程的“Hello world”,现在有了jQuery版本。 源码 jQuery疯狂填词游戏 这是一个填空游戏,由于不知道单词的上下文,可能会产生一些古怪的结果。 源码 jQuery扫雷游戏

本教程演示了如何使用jQuery创建迷人的视差背景效果。 我们将构建一个带有分层图像的标题横幅,从而创造出令人惊叹的视觉深度。 更新的插件可与JQuery 1.6.4及更高版本一起使用。 下载

本文讨论了在浏览器中优化JavaScript性能的策略,重点是减少执行时间并最大程度地减少对页面负载速度的影响。

本文演示了如何使用jQuery和ajax自动每5秒自动刷新DIV的内容。 该示例从RSS提要中获取并显示了最新的博客文章以及最后的刷新时间戳。 加载图像是选择

Matter.js是一个用JavaScript编写的2D刚体物理引擎。此库可以帮助您轻松地在浏览器中模拟2D物理。它提供了许多功能,例如创建刚体并为其分配质量、面积或密度等物理属性的能力。您还可以模拟不同类型的碰撞和力,例如重力摩擦力。 Matter.js支持所有主流浏览器。此外,它也适用于移动设备,因为它可以检测触摸并具有响应能力。所有这些功能都使其值得您投入时间学习如何使用该引擎,因为这样您就可以轻松创建基于物理的2D游戏或模拟。在本教程中,我将介绍此库的基础知识,包括其安装和用法,并提供一


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

SecLists
SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

EditPlus 中文破解版
体积小,语法高亮,不支持代码提示功能

适用于 Eclipse 的 SAP NetWeaver 服务器适配器
将Eclipse与SAP NetWeaver应用服务器集成。

Atom编辑器mac版下载
最流行的的开源编辑器

PhpStorm Mac 版本
最新(2018.2.1 )专业的PHP集成开发工具