我是靠谱客的博主 顺利朋友,这篇文章主要介绍js中map()、some()、every()、filter()的区别,现在分享给大家,希望可以做个参考。

js的Array对象有map、some、every、filter几个方法都能对数组中的每个对象进行处理,但是他们之间的功能又各有差别,所以在记下。

  • map():通过指定函数处理数组的每个元素,并返回处理后的数组。
复制代码
1
2
3
4
5
1 var numbers = [4, 9, 16, 25]; 2 3 function myFunction() { 4 console.log(numbers.map(Math.sqrt)); 5 }

输出结果为:

复制代码
1
2,3,4,5

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

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

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

  • some():用于检测数组中的元素是否满足指定条件(函数提供)
复制代码
1
2
3
4
5
6
7
8
9
1 var ages = [3, 10, 18, 20]; 2 3 function checkAdult(age) { 4 return age >= 18; 5 } 6 7 function myFunction() { 8 console.log(ages.some(checkAdult)); 9 }

输出为:true

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

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

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

  • every:用于检测数组所有元素是否都符合指定条件(通过函数提供)
复制代码
1
2
3
4
5
6
7
8
9
1 var ages = [32, 33, 16, 40]; 2 3 function checkAdult(age) { 4 return age >= 18; 5 } 6 7 function myFunction() { 8 console.log(ages.every(checkAdult)); 9 }

输出结果:false

every和some正好相反:

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

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

  • filter:创建一个新的数组,新数组中的元素是通过检查指定数组中符合条件的所有元素

 

复制代码
1
2
3
4
5
6
7
8
9
1 var ages = [32, 33, 16, 40]; 2 3 function checkAdult(age) { 4 return age >= 18; 5 } 6 7 function myFunction() { 8 console.log(ages.filter(checkAdult)); 9 }

输出结果:

复制代码
1
2
32,33,40

 filter会根据函数中的筛选条件将返回的结果组成一个新的数组并返回

转载于:https://www.cnblogs.com/redsquirrel/p/11546534.html

最后

以上就是顺利朋友最近收集整理的关于js中map()、some()、every()、filter()的区别的全部内容,更多相关js中map()、some()、every()、filter()内容请搜索靠谱客的其他文章。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(87)

评论列表共有 0 条评论

立即
投稿
返回
顶部