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

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]
再比如处理对象:
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方法的使用的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1535339.html
微信扫一扫
支付宝扫一扫