JavaScript之filter_动力节点Java学院整理
2017-06-28 10:11
786 查看
filter也是一个常用的操作,它用于把Array的某些元素过滤掉,然后返回剩下的元素。
和map()类似,Array的filter()也接收一个函数。和map()不同的是,filter()把传入的函数依次作用于每个元素,然后根据返回值是true还是false决定保留还是丢弃该元素。
例如,在一个Array中,删掉偶数,只保留奇数,可以这么写:
var arr = [1, 2, 4, 5, 6, 9, 10, 15]; var r = arr.filter(function (x) { return x % 2 !== 0; }); r; // [1, 5, 9, 15]
把一个Array中的空字符串删掉,可以这么写:
var arr = ['A', '', 'B', null, undefined, 'C', ' ']; var r = arr.filter(function (s) { return s && s.trim(); // 注意:IE9以下的版本没有trim()方法 }); r; // ['A', 'B', 'C']
可见用filter()这个高阶函数,关键在于正确实现一个“筛选”函数。
练习
请尝试用filter()筛选出素数
您可能感兴趣的文章:
相关文章推荐
- JavaScript简介_动力节点Java学院整理
- JavaScript条件判断_动力节点Java学院整理
- JavaScript之生成器_动力节点Java学院整理
- JavaScript之underscore_动力节点Java学院整理
- JavaScript原型继承_动力节点Java学院整理
- JavaScript对象_动力节点Java学院整理
- JavaScript之promise_动力节点Java学院整理
- JavaScript之iterable_动力节点Java学院整理
- JavaScript之Map和Set_动力节点Java学院整理
- JavaScript之class继承_动力节点Java学院整理
- JavaScript数据类型和变量_动力节点Java学院整理
- JavaScript高阶函数_动力节点Java学院整理
- JavaScript标准对象_动力节点Java学院整理
- JavaScript之map reduce_动力节点Java学院整理
- JavaScript之RegExp_动力节点Java学院整理
- JavaScript脚本语言是什么_动力节点Java学院整理
- JavaScript创建对象_动力节点Java学院整理
- JavaScript方法_动力节点Java学院整理
- JavaScript操作文件_动力节点Java学院整理
- JavaScript之DOM_动力节点Java学院整理