更新:你说过你想math.add
用所有的值调用一次,但我认为它不支持这样做。该函数的文档和来源都说它只支持两个参数,而不是无限的系列。
所以你不能一次完成所有的事情;你最好在解析时这样做:
exports.add = function(req, res) {
var v = req.params.v;
var array = v.split(",");
var result = 0;
for(var i=0; i<array.length; i++) {
result = math.add(result, +array[i]);
}
res.end(result.toString());
}
或者在启用 ES5(或 shimed)的环境中:
exports.add = function(req, res) {
var result = 0;
req.params.v.split(",").forEach(function(val) {
result = math.add(result, val);
});
res.end(result.toString());
}
但既然你知道这些是 JavaScript 数字,我看不出有任何使用math.add
的理由。它只是将它们加在一起,允许各种类型。但是你知道这些数字的类型,所以除了调用它的开销之外,你什么也得不到。
在我去寻找之前的原始答案:
它需要单独的整数来处理。我可以将函数与 array[0],array[1] 一起使用,但我想使用单个变量一次提供所有整数。
如果math.add
支持一系列离散参数,您可以像这样使用您的数组:
var result = math.add.apply(math, intarray);
apply
调用你调用它的函数,使用你给它的第一个参数作为this
调用中的值,并将你作为第二个参数提供的数组的内容作为函数的各个参数。
举个例子更容易理解:
/// A function accepting three formal arguments
function foo(a, b, c) {
console.log("a = " + a);
console.log("b = " + b);
console.log("c = " + c);
}
// An array with 1, 2, 3 in it
var a = [1, 2, 3];
// Call `foo`, passing in the array to use as the discrete arguments
foo.apply(undefined, a);
输出:
a = 1
b = 2
c = 3
在那个例子中,我不需要this
在对 的调用中做任何特别的事情foo
,所以我使用了undefined
. 当调用对象的方法(math.add
例如)时,最好使用对象,因为这this
通常是调用中的内容。