JavaScript中map()和filter()的使用区别

 更新时间:2025年05月08日 10:24:44   作者:胡歌1  
map()和filter()都是 JavaScript数组的高阶函数,本文主要介绍了JavaScript中map()和filter()的使用区别,具有一定的参考价值,感兴趣的可以了解一下

map() 和 filter() 都是 JavaScript 数组的高阶函数,但它们的用途和行为有本质区别:

核心区别对比表

特性map()filter()
用途转换数组元素筛选数组元素
返回值新数组(与原数组长度相同)新数组(长度≤原数组)
回调返回要求返回转换后的元素返回布尔值(决定是否保留元素)
空位处理保留空位(返回undefined)跳过空位
是否修改原数组不修改原数组(纯函数)不修改原数组(纯函数)

代码示例对比

示例数组

const numbers = [1, 2, 3, 4, 5];
const users = [
  { id: 1, name: 'Alice', active: true },
  { id: 2, name: 'Bob', active: false },
  { id: 3, name: 'Charlie', active: true }
];

map() 示例

// 将每个数字平方
const squares = numbers.map(n => n * n);
console.log(squares); // [1, 4, 9, 16, 25]

// 提取用户名数组
const names = users.map(user => user.name);
console.log(names); // ['Alice', 'Bob', 'Charlie']

// 处理空位
const sparse = [1, , 3];
const mapped = sparse.map(x => x * 2);
console.log(mapped); // [2, , 6]

filter() 示例

// 筛选偶数
const evens = numbers.filter(n => n % 2 === 0);
console.log(evens); // [2, 4]

// 筛选活跃用户
const activeUsers = users.filter(user => user.active);
console.log(activeUsers); 
// [{id:1,name:'Alice',active:true}, {id:3,name:'Charlie',active:true}]

// 处理空位
const sparse = [1, , 3];
const filtered = sparse.filter(x => true);
console.log(filtered); // [1, 3] (空位被跳过)

关键区别详解

1. 用途不同

map() 用于 转换/映射 数组元素

// 将温度从摄氏度转换为华氏度
const celsius = [0, 10, 20];
const fahrenheit = celsius.map(c => c * 9/5 + 32);
console.log(fahrenheit); // [32,50,68]

filter() 用于 筛选 数组元素

// 筛选正数
const temps = [-2, 5, -10, 15];
const positiveTemps = temps.filter(t => t > 0);
console.log(positiveTemps); //[5,15]

2. 返回值不同

map() 总是返回 等长数组

[1, 2, 3].map(x => x * 2); // [2, 4, 6] (长度保持3)

filter() 返回 可能更短的数组

[1, 2, 3].filter(x => x > 1); // [2, 3] (长度变为2)

3. 回调函数要求不同

map() 回调返回 任意类型值

[1, 2].map(x => ({ value: x })); // 返回对象数组:  [{value:1}, {value:2}]

filter() 回调必须返回 布尔值

[1, 2].filter(x => x % 2 === 0); // 必须返回true/false // [2]

组合使用示例

两者常结合使用实现复杂逻辑:

// 获取所有活跃用户的名字
const activeNames = users
  .filter(user => user.active)    // 先筛选
  .map(user => user.name);        // 再转换
console.log(activeNames);         // ['Alice', 'Charlie']

// 计算所有正数的平方根
const numbers = [4, -1, 9, -5, 16];
const positiveRoots = numbers
  .filter(n => n > 0)            // 筛选正数
  .map(n => Math.sqrt(n));       // 计算平方根
console.log(positiveRoots );     // [2, 3, 4]

性能注意事项

map() 总会遍历所有元素

filter() 也总会遍历所有元素

当链式调用时,考虑顺序优化:

// 更高效的写法:先筛选再转换(减少map操作次数)
bigArray.filter(x => x > 10).map(x => x * 2);

// 低效写法(会先对所有元素执行转换)
bigArray.map(x => x * 2).filter(x => x > 20);

特殊场景处理

处理稀疏数组

const sparse = [1, , , 4];

// map会保留空位
const mapSparse = sparse.map(x => x * 2); 
console.log(mapSparse); // [2, , , 8]

// filter会跳过空位
const filterSparse =sparse.filter(x => true); 
console.log(filterSparse); // [1, 4]

处理数组中的假值

const mixed = [0, 1, false, 2, '', 3];

// filter可以用于移除假值
const truths = mixed.filter(Boolean); // [1, 2, 3]

总结选择指南

  • 需要 转换每个元素 → 用 map()

  • 需要 基于条件筛选元素 → 用 filter()

  • 需要 既筛选又转换 → 组合使用(通常先filter后map)

  • 需要 保持数组长度 → 只能用 map()

  • 需要 移除特定元素 → 用 filter()

 到此这篇关于JavaScript中map()和filter()的使用区别的文章就介绍到这了,更多相关JavaScript map()和filter()内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 浅谈js的html元素的父节点,子节点

    浅谈js的html元素的父节点,子节点

    下面小编就为大家带来一篇浅谈js的html元素的父节点,子节点。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-08-08
  • 微信小程序自定义胶囊样式

    微信小程序自定义胶囊样式

    这篇文章主要为大家详细介绍了微信小程序自定义胶囊样式,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-12-12
  • JS实现JSON.stringify的实例代码讲解

    JS实现JSON.stringify的实例代码讲解

    JSON.stringify是浏览器高版本带的一个将JS的Objtect对象转换为JSON字符串的一个方法,不过再IE6下面,并不存在JSON这一对象,因此,用到此方法时,需要写一套兼容性的代码。接下来通过本文给大家分享JS实现JSON.stringify的实例代码,需要的朋友参考下吧
    2017-02-02
  • 将html页面保存成图片,图片写入pdf的实现方法(推荐)

    将html页面保存成图片,图片写入pdf的实现方法(推荐)

    下面小编就为大家带来一篇将html页面保存成图片,图片写入pdf的实现方法(推荐)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-09-09
  • 原生JS实现日历组件的示例代码

    原生JS实现日历组件的示例代码

    本篇文章主要介绍了原生JS实现日历组件的示例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-09-09
  • 关于JS中一维数组和二维数组互转问题

    关于JS中一维数组和二维数组互转问题

    这篇文章主要介绍了js中一维数组和二维数组互转,本文结合示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-04-04
  • js实现前端图片上传即时预览功能

    js实现前端图片上传即时预览功能

    这篇文章主要为大家详细介绍了js实现前端图片即时预览功能,本地预览功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-08-08
  • js实现图片上传并预览功能

    js实现图片上传并预览功能

    这篇文章主要为大家详细介绍了js实现图片上传并预览功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-08-08
  • js中异步函数async function变同步函数的简单入门

    js中异步函数async function变同步函数的简单入门

    这篇文章主要介绍了js中异步函数async function变同步函数的简单入门,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-04-04
  • JavaScript的高级概念和用法详解

    JavaScript的高级概念和用法详解

    JavaScript语言不断发布一些新特性,感觉要上天的节奏啊。本文搜集整理了一些它的高级概念和用法,需要的朋友可以参考下
    2022-07-07

最新评论