1

以下是代码,这里我们只讲解这段代码

function cakes(recipe, available) {
  return Object.keys(recipe).reduce(function(val, ingredient) {
    return Math.min(Math.floor(available[ingredient] / recipe[ingredient] || 0), val)
  }, Infinity)  
}

Object.keys()

首先是Object.keys(),这里我刚看到的时候并不知道这是什么方法,然后去MDN查了查这个方法,发现

Object.keys()方法会返回一个由给定对象的所有可枚举自身属性的属性名组成的数组,数组中属性名的排列顺序和使用for-in循环遍历该对象时返回的顺序一致 (顺序一致不包括数字属性)(两者的主要区别是 for-in 还会遍历出一个对象从其原型链上继承到的可枚举属性)。

需要注意的是:

1.返回一个对象的所有可枚举自身属性的属性名组成的数组

// getFoo是个不可枚举的属性
var my_obj = Object.create({}, { getFoo : { value : function () { return this.foo } } });
my_obj.foo = 1;

alert(Object.keys(my_obj)); // 只弹出foo

2.属性名的排列顺序

//具有随机键排序的数组类对象
var an_obj = { 100: 'a', 2: 'b', 7: 'c' };
console.log(Object.keys(an_obj)); // console: ['2', '7', '100']

3.for-in会遍历出这个对象从原型链继承到的可枚举属性,而keys()不会

reduce()

arr.reduce(callback,[initialValue]),这里initialValue是第一次调用callback时的第一个参数

[0,1,2,3,4].reduce( (accumulator, currentValue, currentIndex, array) => {
  return accumulator + currentValue;
}, 10); //结果为10+0+1+2+3+4=20

luckyziv
1.2k 声望52 粉丝

摸索中前进!!