[JavaScript基础]学习①⑤--高阶函数filter

filter()把传入的函数依次作用于每个元素,然后根据返回值是true还是false决定保留还是丢弃该元素

保留奇数

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]

删掉空字符串

var arr = ['A', '', 'B', null, undefined, 'C', '  '];
var r = arr.filter(function (s) {
    return s && s.trim(); // 注意:IE9以下的版本没有trim()方法
});
r; // ['A', 'B', 'C']

回调函数

第一个参数 元素
第二个参数 元素位置
第三个参数 数组

var arr = ['A', 'B', 'C'];
var r = arr.filter(function (element, index, self) {
    console.log(element); // 依次打印'A', 'B', 'C'
    console.log(index); // 依次打印0, 1, 2
    console.log(self); // self就是变量arr
    return true;
});

去除Array的重复元素

'use strict';

var
    r,
    arr = ['apple', 'strawberry', 'banana', 'pear', 'apple', 'orange', 'orange', 'strawberry'];
r = arr.filter(function (element, index, self) {
    return self.indexOf(element) === index;
});
alert(r.toString());

筛选出素数

'use strict';

function get_primes(arr) {
var i;
return arr.filter(function(ele) {
    // 不包含1和本身,范围:[2, ele)
    for (i = 2; i < ele; i++) {
        // 判断是否能被整除
        if (ele % i === 0) {
            // 将当前ele过滤
            return false;
        }
    }
    // 范围外的只要满足大于1即可
    return ele > 1;
})
}

你可能感兴趣的:([JavaScript基础]学习①⑤--高阶函数filter)