0

如何在var auto没有明确方式的情况下调用每个对象?

我的意思是不必将它们中的每一个都写在函数调用、speedAverage函数和return计算平均值中。

function Car (model, speed) {
    this.model = model;
    this.speed = speed;
}


var speedAverage = function(car1, car2, car3) {
    return (car1.speed + car2.speed + car3.speed)/ veh.length;
};



var auto = [
new Car("BMW", 220),
new Car("Ford", 260),
new Car("DeLorean", 350)
];

console.log("The average between these cars is " + speedAverage(auto[0], auto[1], 
auto[2]));

谢谢。

4

4 回答 4

2

您可以使用该apply方法非常轻松地做到这一点。该函数用于调用以数组内容为参数的函数:

speedAverage.apply(null, auto);
于 2013-11-06T09:58:34.083 回答
0

我想你想将数组对象传递给函数:

var speedAverage = function (arr) {
  var sum=0
  for(var i=0; i<arr.length; i++) {
     sum += arr[i];
  }
  return sum/arr.length;
}

并用 speedAverage (auto) 调用它

如果您正在寻找具有可变数量参数的函数,您还可以阅读有关参数的信息。

于 2013-11-06T10:02:21.557 回答
0

在构造函数中添加一个静态函数Car并推动速度,然后您不必这样做auto

var speeds = [];
function Car (model, speed) {
    this.model = model;
    this.speed = speed;
    speeds.push(speed);
}

Car.getAverageSpeed = function() {
  return eval(speeds.join('+'))/speeds.length;
};

new Car("BMW", 220),
new Car("Ford", 260),
new Car("DeLorean", 350)

console.log("The average between these cars is " + Car.getAverageSpeed());

或者你可以像这样使用argumentsapply()

var speedAverage = function() {
    return eval(Array.prototype.map.call(arguments, function(s) {
        return s.speed;
    }).join('+'))/arguments.length;
};

var auto = [
    new Car("BMW", 220),
    new Car("Ford", 260),
    new Car("DeLorean", 350)
];

console.log("The average between these cars is " + speedAverage.apply(0, auto));
于 2013-11-06T10:39:38.777 回答
0

由于您已经在auto数组中拥有所有数据,请使用 reduce 函数:

console.log (auto.reduce (
   function (speed, car) { 
     return speed + car.speed; 
   }, 0) / auto.length);

调用reduce返回 中所有汽车的速度总和auto,除以汽车数量,得出平均值。

于 2013-11-06T11:11:22.480 回答