filter也是一個(gè)常用的操作,它用于把Array的某些元素過(guò)濾掉贴硫,然后返回剩下的元素椿每。
和map()類似伊者,Array的filter()也接收一個(gè)函數(shù)。和map()不同的是间护,filter()把傳入的函數(shù)依次作用于每個(gè)元素亦渗,然后根據(jù)返回值是true還是false決定保留還是丟棄該元素。
例如汁尺,在一個(gè)Array中法精,刪掉偶數(shù),只保留奇數(shù)痴突,可以這么寫:
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]
把一個(gè)Array中的空字符串刪掉搂蜓,可以這么寫:
var arr = ['A', '', 'B', null, undefined, 'C', ' '];
var r = arr.filter(function (s) {
return
})
可見用filter()這個(gè)高階函數(shù),關(guān)鍵在于正確實(shí)現(xiàn)一個(gè)“篩選”函數(shù)辽装。
回調(diào)函數(shù)
filter()接收的回調(diào)函數(shù)帮碰,其實(shí)可以有多個(gè)參數(shù)。通常我們僅使用第一個(gè)參數(shù)拾积,表示Array的某個(gè)元素殉挽。回調(diào)函數(shù)還可以接收另外兩個(gè)參數(shù)拓巧,表示元素的位置和數(shù)組本身:
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;
});
利用filter,可以巧妙的去除Array的重復(fù)元素:
'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());
//返回 apple, strawberry, banana, pear, orange,
//去除重復(fù)元素依靠的是indexOf總是返回第一個(gè)元素的位置,后續(xù)的重復(fù)元素位置與indexOf返回的位置不相等玲销,因此被filter濾掉了输拇。
請(qǐng)嘗試用filter() 篩選出素?cái)?shù):
'use strict';
function get_primes(arr) {
return arr.filter(function (x) {
var filter = 1;
for (var i = 2; i < x; i++) {
if ((x / i) % 1 === 0) {
filter = 0;
}
}
if (x === 1) {
filter = 0;
}
return filter;
});
}
// 測(cè)試:
var
x,
r,
arr = [];
for (x = 1; x < 100; x++) {
arr.push(x);
}
r = get_primes(arr);
if (r.toString() === [2, 3, 5, 7, 11, 13, 17, 19, 23, 29, 31, 37, 41, 43, 47, 53, 59, 61, 67, 71, 73, 79, 83, 89, 97].toString()) {
alert('測(cè)試通過(guò)!');
} else {
alert('測(cè)試失敗: ' + r.toString());
}