js的map, filter,some,every,find的区别

一、map():通过指定函数处理数组的每个元素,并返回处理后的数组。
var numbers = [4, 9, 16, 25];

function myFunction() {
console.log(numbers.map(Math.sqrt)); // 2,3,4,5
}

map() 方法会将数组中元素依次传入方法中,并将方法的返回结果组成新数组返回。

传入的function可以有自己的三个形参,currentValue, index,arr分别代表当前元素,元素索引,元素所属数组对象;其中currentValue是必须的。

注意:map不会改变原数组,map不会检查空数组

二、some():用于检测数组中的元素是否满足指定条件(函数提供)
var ages = [3, 10, 18, 20];

function checkAdult(age) {
return age >= 18;
}

function myFunction() {
console.log(ages.some(checkAdult)); // true
}

some方法会依次执行数组的每个元素;

如果有一个元素满足条件,则表达式返回true , 剩余的元素不会再执行检测
如果没有满足条件的元素,则返回false

三、every:用于检测数组所有元素是否都符合指定条件(通过函数提供)

var ages = [32, 33, 16, 40];

function checkAdult(age) {
return age >= 18;
}

function myFunction() {
console.log(ages.every(checkAdult)); //false
}

every和some正好相反:

如果数组中检测到有一个元素不满足,则整个表达式返回 false ,且剩余的元素不会再进行检测。
如果所有元素都满足条件,则返回 true。

注意:some不会改变原数组,some不会检查空数组

四、filter:创建一个新的数组,新数组中的元素是通过检查指定数组中符合条件的所有元素
var ages = [32, 33, 16, 40];

function checkAdult(age) {
return age >= 18;
}

function myFunction() {
console.log(ages.filter(checkAdult)); //32,33,40
}

五、find:返回符合条件的第一个数组元素值,没有则返回 undefined

总结如下

1.every和some
every:全部条件都正确才返回true
some:有一个条件正确就返回true

2.filter和find
filter:返回满足条件的集合,一个新数组(筛选出满足条件的新数组)
find:返回符合条件的第一个数组元素值,没有则返回 undefined

你可能感兴趣的:(javascript,javascript)