首页 > web前端 > js教程 > 正文

js数组中filter方法的使用

尊渡假赌尊渡假赌尊渡假赌
发布: 2025-11-04 01:49:33
原创
414人浏览过
filter()方法创建新数组包含满足条件的元素,体现不可变性;语法为arr.filter(callback, thisArg),callback接收element、index、array参数;常用于筛选数字、对象属性或去重;可与map、sort等链式调用处理数据,如先过滤成人用户再提取姓名;原数组不变,无匹配则返回空数组。

js数组中filter方法的使用

JavaScript 中的 filter() 方法用于创建一个新数组,这个新数组包含通过指定条件的所有元素。原数组不会被修改,这是函数式编程中常见的“不可变性”原则体现。

基本语法

arr.filter(callback(element, index, array), thisArg)

  • callback:用来测试每个元素的函数,返回 true 则保留该元素,false 则过滤掉
  • element:当前遍历的元素
  • index(可选):当前元素的索引
  • array(可选):调用 filter 的原数组
  • thisArg(可选):执行 callback 时的 this 值

常见使用场景

filter 非常适合从数组中筛选出符合条件的数据。

  • 筛选数字:比如找出所有大于 10 的数
  • 处理对象数组:比如找出年龄大于 18 的用户
  • 去重或排除特定值:比如去掉 null、undefined 或空字符串

例如:

const numbers = [5, 10, 15, 20];
const bigNumbers = numbers.filter(n => n > 10);
// 结果:[15, 20]

再比如处理对象:

SpeakingPass-打造你的专属雅思口语语料
SpeakingPass-打造你的专属雅思口语语料

使用chatGPT帮你快速备考雅思口语,提升分数

SpeakingPass-打造你的专属雅思口语语料 25
查看详情 SpeakingPass-打造你的专属雅思口语语料
const users = [
{ name: 'Alice', age: 25 },
{ name: 'Bob', age: 17 },
{ name: 'Charlie', age: 30 }
];
const adults = users.filter(user => user.age >= 18);
// 结果:包含 Alice 和 Charlie 的新数组

结合其他方法使用

filter 经常和 map、sort 等方法链式调用,实现更复杂的数据处理。

例如先筛选再提取名字:

const names = users
.filter(u => u.age >= 18)
.map(u => u.name);
// 结果:['Alice', 'Charlie']

注意:filter 不会改变原数组,每次调用都返回一个新数组。如果没有任何元素满足条件,返回空数组 []。

基本上就这些。filter 简洁又强大,是日常开发中最常用的数组方法之一。

以上就是js数组中filter方法的使用的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

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