• 干货!如何用.map() .filter() 和.reduce()给代码做“减法”


    Map

    .map()方法使用在:1.用可迭代的每个值执行一组语句;2.返回(可能)修改值。

    用一个简单的示例来计算一系列价格的营业税:

    const prices = [19.99, 4.95, 25, 3.50];
      let new_prices = [];for(let i=0; i < prices.length; i++) {
      new_prices.push(prices[i] * 1.06);
    }

    用.map()方法可以得出同样的结果:

    const prices= [19.99, 4.95, 25, 3.50];let new_prices = prices.map(price => price *1.06);

    上面的语法简明扼要,所以简单过一遍即可。

    .map()函数采用回调,可以将其视为一个函数,这便是括号之间的含义。

    price变量用于标识每个值的名称,由于只有一个变量输入,所以可以省略参数周围的常用括号。

    箭头=>后的语句是回调的主体。由于主体只有一条语句,可以省略大括号和return关键字。

    以防部分学习者无法理解,具体代码如下,供详细参考:

    const prices= [19.99, 4.95, 25, 3.50];let new_prices = prices.map((price) => {
        return price * 1.06
    });

    Filter

    当要从可迭代对象中提取值的子集时,.filter() 方法就派上了用场。使用.filter()时,请记住是在筛选值,而不是筛除值。这就意味着,迭代器中评估为true的每个项目,都将包含在过滤器中。

    举一个只保留奇数的例子:使用模运算符来计算除以2的余数。当余数等于1,就得知这个数是奇数。

    const numbers = [1,2,3,4,5,6,7,8];
    let odds = [];for(let i=0; i < numbers.length; i++) {
      if(numbers[i] % 2 == 1) {
        odds.push(numbers[i]);
      }
    }
    const numbers = [1,2,3,4,5,6,7,8];let odds = numbers.filter(num => num % 2);

    此回调也适用类似的规则。由于只有一个输入,且函数的主体是单个表达式,因此可以省略参数列表括号、定义主体的大括号和return关键字。

    Reduce

    最后,来看看.reduce()。诚然,它是三种方法中最让人困惑的方法。从术语名称来看,Reduce方法是指将多个值缩减为一个。然而,笔者发现,与“减少”相比,把它想成是“积累”更容易操作。

    该方法通过定义起点来运行。当该方法迭代每个值时,该起点将被修改并向下传递。

    这是将一系列数字相加的经典案例。假设正在计算某人最喜欢的慈善机构的捐款总额:

    constdonations = [5, 20, 100, 80, 75];
      let total = 0;for(let i=0; i < donations.length; i++) {
      total += donations[i];
    }

    与.map()和.filter()不同,.reduce()方法的回调需要两个参数:累加器和当前值。累加器将是第一个参数,是“向下传递”值。

    constdonations = [5, 20, 100, 80, 75];let total = donations.reduce((total,donation)=> {
      return total + donation;
    });

    还可以将第二个参数传递给 .reduce()函数本身,作为累加器的起始值。假设加上昨天总共450美元的捐款。

    constdonations = [5, 20, 100, 80, 75];let total = donations.reduce((total,donation)=> {
      return total + donation;
    }, 450);

    然后就能得到运行结果,这些方法并不可怕,它们能让代码更具可读性!这样就可以编写更精简的代码啦,更重要的是,这实际上是在描述循环意图!

    在三个月后回顾代码时,我们的阅读将变得更轻松。不必阅读for循环中的语句,只需理解它的高级意图,就可以看到map/filter/reduce方法,并能开始对该块试图实现的目标有所想法了。

  • 相关阅读:
    电感
    电容
    电阻
    函数异常规格说明
    异常处理深度解析
    自定义内存管理
    单例类模板
    数组类模板
    数组类模板
    类模板深度剖析
  • 原文地址:https://www.cnblogs.com/pwindy/p/12971008.html
Copyright © 2020-2023  润新知