美文网首页IT修真院-前端让前端飞程序员
对一个数组 FILTER、SOME、MAP、FOREACH的操作

对一个数组 FILTER、SOME、MAP、FOREACH的操作

作者: 我是一只北极熊啊 | 来源:发表于2017-12-23 13:40 被阅读31次

    大家好,我是IT修真院北京总院第24期的学员,一枚正直纯洁善良的web程序员

    今天给大家分享一下,修真院官网JS任务4,深度思考中的知识点——对一个数组 FILTER、SOME、MAP、FOREACH的操作分别有什么作用?

    1.背景介绍

    循环(loop),指的是在满足条件的情况下,重复执行同一段代码。比如,while语句。

    迭代(iterate),指的是按照某种顺序逐个访问列表中的每一项。比如,for语句。

    遍历(traversal),指的是按照一定的规则访问树形结构中的每个节点,而且每个节点都只访问一次。

    递归(recursion),指的是一个函数不断调用自身的行为。

    数组,在编程语言中很重要,其中every()、filter()、some()、map()、forEach()是ECMAScript5为数组定义的5个迭代方法,是为了更方便的对数组进行操作。

    2.知识剖析

    首先,每个方法都接收两个参数:

    (1)要在每一项上运行的函数。

    (2)运行该函数的作用域对象—this(可选)

    array.forEach(function () {

    //do your staff here;

    }, this);

    传入这些方法中的函数参数本身会接收三个参数:

    1、数组项的值;

    2、该项在数组中的位置;

    3、数组对象本身;

    array.forEach(function (item, index, array) {

    //do your staff here;

    }, 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要事先计算出来,而在处理非常大量的数据时候, 后者的优势就显而易见了。

    json对象的转换方法,两次转换

    7.参考文献

    参考1:Js 数组——filter()、map()、some()、every()、forEach()、lastIndexOf()、indexOf()

    参考2:《JS高级程序设计》

    参考3:js数组操作--使用迭代方法替代for循环

    8.更多讨论

    无提问

    视频链接

    ppt链接

    感谢大家观看

    今天的分享就到这里啦,欢迎大家点赞、转发、留言、拍砖~

    技能树.IT修真院

    “我们相信人人都可以成为一个工程师,现在开始,找个师兄,带你入门,掌控自己学习的节奏,学习的路上不再迷茫”。

    这里是技能树.IT修真院,成千上万的师兄在这里找到了自己的学习路线,学习透明化,成长可见化,师兄1对1免费指导。快来与我一起学习吧~

    我的邀请码:12361358,或者你可以直接点击此链接:http://www.jnshu.com/login/1/12361358

    相关文章

      网友评论

        本文标题:对一个数组 FILTER、SOME、MAP、FOREACH的操作

        本文链接:https://www.haomeiwen.com/subject/zlvfgxtx.html