0

0

js如何过滤数组元素 数组过滤的3种高效方法解析

穿越時空

穿越時空

发布时间:2025-06-26 18:04:02

|

666人浏览过

|

来源于php中文网

原创

javascript过滤数组元素主要使用filter()方法。1. filter()通过检查数组中符合条件的元素并创建新数组,如const evennumbers = numbers.filter(number => number % 2 === 0); //输出偶数。2. 其他方法包括:map() + reduce()组合实现复杂过滤,但代码较冗长;原始for循环手动筛选,灵活但易出错;lodash库的_.filter()用法与原生类似,性能可能更优。3. filter()支持复杂条件,可将判断逻辑封装为函数以提升可读性。4. filter()不会修改原数组,而是返回新数组。5. filter()接收三个参数,包括当前元素、索引和原数组,可用于按索引过滤。6. 对于null和undefined,默认被跳过,可通过显式判断保留或排除。总体上,filter()是最常用且便捷的数组过滤方法。

js如何过滤数组元素 数组过滤的3种高效方法解析

直接告诉你,JavaScript过滤数组元素,主要靠filter()方法。当然,还有一些其他奇技淫巧,但filter()绝对是主力。

js如何过滤数组元素 数组过滤的3种高效方法解析

解决方案

filter()方法创建一个新数组,新数组中的元素是通过检查指定数组中符合条件的所有元素。 简单来说,就是你给它一个条件,它把满足条件的元素都挑出来,放到一个新的数组里。

js如何过滤数组元素 数组过滤的3种高效方法解析

举个例子:

js如何过滤数组元素 数组过滤的3种高效方法解析
const numbers = [1, 2, 3, 4, 5, 6];

const evenNumbers = numbers.filter(number => number % 2 === 0);

console.log(evenNumbers); // 输出: [2, 4, 6]

这段代码里,filter()接收一个箭头函数作为参数,这个箭头函数就是用来判断元素是否符合条件的。 number % 2 === 0 这个条件的意思是,如果一个数除以2余数为0,那么它就是偶数,就把它放到新数组里。

JavaScript中除了filter()还有哪些数组过滤方法?

除了filter(),还有一些其他方法也能实现数组过滤,但它们的应用场景可能不太一样。

  • map() + reduce() map()先对数组进行转换,然后reduce()再进行过滤。 这种方法比较灵活,但代码相对复杂,效率也可能不如filter()

    const numbers = [1, 2, 3, 4, 5, 6];
    
    const evenNumbers = numbers.map(number => number % 2 === 0 ? number : null)
                                 .reduce((acc, number) => {
                                     if (number !== null) {
                                         acc.push(number);
                                     }
                                     return acc;
                                 }, []);
    
    console.log(evenNumbers); // 输出: [ null, 2, null, 4, null, 6 ]  //注意这里的null
    
    //改进一下
    const evenNumbersImproved = numbers.map(number => number % 2 === 0 ? number : undefined)
                                 .filter(number => number !== undefined);
    
    console.log(evenNumbersImproved); // 输出: [ 2, 4, 6 ]

    可以看到,如果不注意,map()可能会引入一些不需要的值,需要额外处理。

  • for循环: 最原始的方法,自己写循环,自己判断,自己往新数组里塞。 这种方法最灵活,但代码最长,也最容易出错。

    const numbers = [1, 2, 3, 4, 5, 6];
    const evenNumbers = [];
    
    for (let i = 0; i < numbers.length; i++) {
        if (numbers[i] % 2 === 0) {
            evenNumbers.push(numbers[i]);
        }
    }
    
    console.log(evenNumbers); // 输出: [2, 4, 6]

    可读性稍差,而且容易出现数组越界之类的问题。

  • lodash库的_.filter() lodash是一个非常流行的JavaScript工具库,它提供了很多方便的函数,包括_.filter()_.filter()的用法和原生的filter()基本一样,但它在一些情况下可能会有更好的性能。

    const numbers = [1, 2, 3, 4, 5, 6];
    
    const evenNumbers = _.filter(numbers, number => number % 2 === 0);
    
    console.log(evenNumbers); // 输出: [2, 4, 6]

    需要引入lodash库,如果你的项目已经使用了lodash,那么用它也是个不错的选择。

总的来说,filter()是最常用,也是最方便的数组过滤方法。 其他方法各有优缺点,可以根据实际情况选择。

如何在filter()中使用复杂的过滤条件?

filter()方法接收的箭头函数,可以写成很复杂的形式,只要最终返回一个布尔值就行。

例如,要过滤出大于3且是偶数的元素:

const numbers = [1, 2, 3, 4, 5, 6];

const filteredNumbers = numbers.filter(number => {
    if (number > 3 && number % 2 === 0) {
        return true;
    } else {
        return false;
    }
});

console.log(filteredNumbers); // 输出: [4, 6]

或者,可以把过滤条件提取成一个单独的函数:

Unscreen
Unscreen

AI智能视频背景移除工具

下载
const numbers = [1, 2, 3, 4, 5, 6];

function isGreaterThan3AndEven(number) {
    return number > 3 && number % 2 === 0;
}

const filteredNumbers = numbers.filter(isGreaterThan3AndEven);

console.log(filteredNumbers); // 输出: [4, 6]

这样代码更清晰,也更容易维护。

filter()会改变原数组吗?

filter()方法不会改变原数组。 它会创建一个新的数组,包含符合条件的元素。

const numbers = [1, 2, 3, 4, 5, 6];

const evenNumbers = numbers.filter(number => number % 2 === 0);

console.log(numbers); // 输出: [1, 2, 3, 4, 5, 6]
console.log(evenNumbers); // 输出: [2, 4, 6]

可以看到,numbers数组并没有被改变。

如何在filter()中访问数组的索引?

filter()方法接收的箭头函数,可以接收三个参数:

  • element:当前元素的值
  • index:当前元素的索引
  • array:原数组

例如,要过滤出索引是偶数的元素:

const numbers = [1, 2, 3, 4, 5, 6];

const filteredNumbers = numbers.filter((number, index) => index % 2 === 0);

console.log(filteredNumbers); // 输出: [1, 3, 5]

注意,这里箭头函数的参数顺序不能错。

filter()的性能如何?

filter()的性能通常很好,尤其是对于小数组。 但对于非常大的数组,性能可能会成为一个问题。

在一些情况下,使用for循环可能会有更好的性能,因为for循环可以避免创建额外的数组。 但filter()的代码更简洁,也更容易阅读,所以在大多数情况下,filter()是更好的选择。

如果确实需要优化性能,可以考虑使用lodash库的_.filter(),或者手动实现一个更高效的过滤函数。

如何处理filter()中的nullundefined

filter()方法会跳过nullundefined元素。

const numbers = [1, null, 3, undefined, 5, 6];

const filteredNumbers = numbers.filter(number => number > 0);

console.log(filteredNumbers); // 输出: [1, 3, 5, 6]

可以看到,nullundefined元素被自动过滤掉了。

如果需要显式地处理nullundefined,可以在箭头函数中进行判断:

const numbers = [1, null, 3, undefined, 5, 6];

const filteredNumbers = numbers.filter(number => number != null && number > 0);

console.log(filteredNumbers); // 输出: [1, 3, 5, 6]

number != null 这个条件可以同时判断number是否为nullundefined

希望这些能帮到你!

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

254

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

1089

2024.03.01

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

562

2023.09.20

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

js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

530

2023.06.20

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

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

76

2026.03.11

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
WEB前端教程【HTML5+CSS3+JS】
WEB前端教程【HTML5+CSS3+JS】

共101课时 | 10.1万人学习

JS进阶与BootStrap学习
JS进阶与BootStrap学习

共39课时 | 3.3万人学习

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

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