无法减少对象内部的数组

时间:2015-09-22 17:58:19

标签: javascript arrays scope reduce

我正在尝试减少对象内部的数组。我回来了

push is not a function 

我已将数组作为空启动,并创建了一个add函数作为第一个参数传入。

function add(a,b) {
        return a +b;
}

var navBarArray = [];
var listArray = [];

var mapping = {
  ".navbar": navBarArray,
  ".list-group": listArray
};

我在映射对象上尝试了这种方法,但它会产生错误

var mapping = {
  ".navbar": Math.round(navBarArray.reduce(add,0) ),
  ".list-group": listArray
};

但是,我的推送不是我的控制台中的功能。

下面是我将函数传递给数组的函数。我可以在函数内部创建一个变量并在那里减少它。但是,这限制了对我的变量的访问,并且在我继续时会使我的功能膨胀。

  Object.keys(mapping).forEach(function(selector) { 
      $(selector).hover(function(evt) {
        console.log('mapping',mapping);
        console.log('selector',selector);
        enteredTime = new Date();
      }, function() {
        var ctime = new Date();
        var time = (ctime.getTime() - enteredTime.getTime())/1000;
        mapping[selector].push(time);

        // *********** this works but not where I need it to*******
        var reduce = Math.round(navBarArray.reduce(add,0) );
        console.log(reduce);
        });
    })

1 个答案:

答案 0 :(得分:2)

更改映射对象,使其具有阵列和总计的单独位置:

var mapping = {
    ".navbar": {
        total: 0,
        times: []
    },
    ".list-group": {
        total: 0,
        times: []
    }
}

然后你做mapping[selector].times.push(time),并将总数加上:

mapping[selector].total = mapping[selector].times.reduce(add, 0);