大家好,我是IT修真院北京分院第23期的学员郭婷婷,一枚正直纯洁善良的WEB前端程序员。
今天给大家分享一下,修真院官网js任务4中涉及的对一个数组 FILTER、SOME、MAP、FOREACH的操作分别有什么作用?
小课堂【北京第229期】
分享人:郭婷婷
1.背景介绍
数组,在编程语言中很重要,其中every()、filter()、some()、map()、forEach()是ECMAScript5为数组定义的5个迭代方法,是为了更方便的对数组进行操作。
2.知识剖析
首先,每个方法都接收两个参数:
(1)要在每一项上运行的函数。
(2)运行该函数的作用域对象—this(可选)
其次,传入这些方法中的函数参数本身会接收三个参数:数组项的值;该项在数组中的位置;数组对象本身。
3.常见问题
EVERY()、FILTER()、SOME()、MAP()、FOREACH()的用法?
4 解决方案
every():对数组的每一项运行给定函数,如果该函数对每一项都返回true,则返回true,否则返回false
some():对数组的每一项运行给定函数,如果该函数对任一项返回true,则返回true
filter():对数组的每一项运行给定函数,返回该函数会返回true的项组成的数组
map():对数组的每一项运行给定函数,返回每次函数调用的结果组成的数组
forEach():对数组的每一项运行给定函数,这个方法没有返回值。
5.编码实战
6.扩展思考
相对于for(),JS数组自定义的数组迭代方式有哪些好处?
在实现相同功能的前提下,后者除了能够节省代码量外,在实现某些功能上的流程中存在很多有意思的优势, 比如forEach相比普通的for循环的优势在于对稀疏数组的处理,会跳过数组中的空位。 for+i在性能测试上是优越于后者,但是前提是,array的length要事先计算出来,而在处理非常大量的数据时候, 后者的优势就显而易见了。
7.参考文献
参考1:Js 数组——filter()、map()、some()、every()、forEach()、lastIndexOf()、indexOf()
参考2:《JS高级程序设计》
参考3:js数组操作--使用迭代方法替代for循环
8 更多讨论
鸣谢
感谢大家观看
BY : 郭婷婷
PPT链接:https://ptteng.github.io/PPT/PPT/js-04-filter&foreach&map&some.html
视频链接:https://pan.baidu.com/s/1qYc9n1y 密码: ctxs
--------------------------------------------------------------------------------------------------------------------
技能树.IT修真院
“我们相信人人都可以成为一个工程师,现在开始,找个师兄,带你入门,掌控自己学习的节奏,学习的路上不再迷茫”。
这里是技能树.IT修真院,成千上万的师兄在这里找到了自己的学习路线,学习透明化,成长可见化,师兄1对1免费指导。快来与我一起学习吧 !
猛戳这里