繁体   English   中英

JavaScript(ES5)中的参数数组

[英]Arguments Array in JavaScript (ES5)

也许那不是我晚上:/非常简单的事情,我想将一个数组作为参数提供给作为参数数组的函数:

function add() {
    var sum = 0;
    for (var i = 0; i < arguments.length; i++) {
        sum += arguments[i];
    }
    return sum;
}

以下作品:

console.log(add(1,2,3,4,5,6));

但是,如果我填充一个数组并将其作为参数,例如:

var myNumbers = [];
for (var i=0; i<100; i++){
    myNumbers.push(i);
}
console.log(add(myNumbers));

麻烦了 我想,我错过了有关arguments数组的重要信息。

我应该如何更改添加功能,以便这两种可能性都可以使用?

arguments对象是类似数组的对象,但不是数组。 它用于表示传递给函数的所有参数。 您仅将一个值传递给该函数,因此您的数组实际上位于arguments对象的索引0处。

但是,在这里使用arguments确实没有多大意义,除非您需要在不定义显式API的情况下动态处理事物。 只需在add函数中声明您的参数即可。

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

如果您想同时支持这两种情况,请按照您的评论进行操作:

function add() {
    var arr = [].concat.apply([], arguments);
    var sum = 0;
    for (var i = 0; i < arr.length; i++) {
        sum += arr[i];
    }
    return sum;
}

的说明 [].concat.apply([], arguments)

  • []. Array.prototype简写,因为它是一个空数组。
  • concat将两个或多个数组合并在一起,或者将一个数组和值合并到该数组中。
  • arguments不是数组,但是由于对象的某些类似于数组的特性-索引项和length属性,许多原型函数都可以在其上使用。
  • apply调用具有给定上下文( this绑定)和任意数量参数的函数。 在这种情况下,我们仍然希望使用数组作为this值,以便能够调用concat ,然后再调用传递给add所有参数。 结果只是将所有参数作为适当的数组。

此解决方案适用于两种情况:

function add() {
    var arr= Array.prototype.slice.call(arguments);
    arr = [].concat.apply([], arr);

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

sum的简单解决方案:

 function add() {
        var arr= Array.prototype.slice.call(arguments);
        arr = [].concat.apply([], arr);

        return arr.reduce(function(f, s){return f + s;}, 0);
    }

这里:

add(1,2,3,4,5,6);

......你调用add与一系列的离散 (分离)的参数,并且在它们中的每显示出来arguments伪阵列,在1 arguments[0]在2 arguments[1]等等

但在这儿:

add(myNumbers);

...您正在用一个参数(数组)调用add 那是在arguments[0]

您将要编写add以适合您的调用方式。 如果要使用离散参数调用它,请按照自己的方式编写。 如果要编写它来接受数组,请让它接受一个参数并遍历该参数(将是数组):

function add(args) {
    //       ^------------- the one argument
    var sum = 0;
    for (var i = 0; i < args.length; i++) {
        sum += args[i];
    }
    return sum;
}

如果要同时处理两者 ,则可以使用Array.isArrayArray.isArray但可调整)来检查第一个参数,以查看它是否为数组,如果是,则使用它;如果不是,则使用arguments

function add(args) {
    if (!Array.isArray(args)) {
        args = arguments;
    }
    var sum = 0;
    for (var i = 0; i < args.length; i++) {
        sum += args[i];
    }
    return sum;
}

旁注: arguments不是数组,而是类似数组的

您可以使用申请

add.apply(null, [1,2,3])

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM