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方法,并能开始对该块试图实现的目标有所想法了。