• 数组的归并、迭代方法


    接着昨天的学习,我发现了数组的一些简便好玩的方法。

    归并方法:

    ECMAScript 5 新增了两个归并数组的方法: reduce() reduceRight() 。这两个方法都会迭
    代数组的所有项,然后构建一个最终返回的值。其中, reduce() 方法从数组的第一项开始,逐个遍历
    到最后。而 reduceRight() 则从数组的最后一项开始,向前遍历到第一项。
    这两个方法都接收两个参数:一个在每一项上调用的函数和(可选的)作为归并基础的初始值。

    传给 reduce() 和 reduceRight() 的函数接收 4 个参数:前一个值、当前值、项的索引和数组对象。这

    个函数返回的任何值都会作为第一个参数自动传给下一项。第一次迭代发生在数组的第二项上,因此第
    一个参数是数组的第一项,第二个参数就是数组的第二项。
    使用 reduce() 方法求数组中所有值之和:

    var values = [1,2,3,4,5];
    var sum = values.reduce(function(prev, cur, index, array){
    return prev + cur;
    });
    alert(sum); //15

    第一次执行回调函数, prev 是 1, cur 是 2。第二次, prev 是 3(1 加 2 的结果) , cur 是 3(数组
    的第三项) 。这个过程会持续到把数组中的每一项都访问一遍,最后返回结果。
    reduceRight() 的作用类似,只不过方向相反而已。

    迭代方法:以下方法都不会修改数组中的包含的值

     every() :对数组中的每一项运行给定函数,如果该函数对每一项都返回 true ,则返回 true 。
     filter() :对数组中的每一项运行给定函数,返回该函数会返回 true 的项组成的数组。
     forEach() :对数组中的每一项运行给定函数。这个方法没有返回值。
     map() :对数组中的每一项运行给定函数,返回每次函数调用的结果组成的数组。
     some() :对数组中的每一项运行给定函数,如果该函数对任一项返回 true ,则返回 true 。

    ECMAScript 5 为数组定义了 5 个迭代方法。每个方法都接收两个参数:要在每一项上运行的函数和
    (可选的)运行该函数的作用域对象——影响 this 的值。传入这些方法中的函数会接收三个参数:数
    组项的值、该项在数组中的位置和数组对象本身。

    栗子:

    var numbers = [1,2,3,4,5,4,3,2,1];
    var filterResult = numbers.filter(function(item, index, array){
    return (item > 2);
    });
    alert(filterResult); //[3,4,5,4,3]
    var numbers = [1,2,3,4,5,4,3,2,1];
    var mapResult = numbers.map(function(item, index, array){
    return item * 2;
    });
    alert(mapResult); //[2,4,6,8,10,8,6,4,2]
    欢迎大家来浏览我的博客,如发现我有写错的地方,欢迎交流指正。
  • 相关阅读:
    Visual Studio Code 上java开发环境搭建
    c++编译时打印宏定义
    git使用
    Let's Encrypt申请证书及使用
    使用docker创建aosp编译环境
    项目中使用protobuf 3.0
    ubuntu14.04 安装mono
    ubuntu14.04 安装apache+mysql+php
    Discuz & UCenter 修改手记
    代码细节重构:请对我的代码指手划脚(四)
  • 原文地址:https://www.cnblogs.com/lulu-beibei/p/4597312.html
Copyright © 2020-2023  润新知