javascript - 如何将函数的参数重新分配回原始参数名称?

标签 javascript arguments symbol-table

我有一个函数可以重新排列另一个函数的参数以满足标准定义。

function main(a, b, c) {
    console.log(a, b, c);                                  // 1 undefined undefined
    console.log(arguments[0], arguments[1], arguments[2]); // 1 undefined undefined

    shiftArgs(arguments, 3); // 3 because I'm expecting 3 arguments.

    console.log(arguments[0], arguments[1], arguments[2]); // null null 1
    console.log(a, b, c);                                  // 1 undefined undefined ***
}



function shiftArgs(args, c) {var i, len; 
   len = args.length; 
   if (len < c) { 
      for (i = c - 1; i >= 0; i -= 1) {
          args[i] = ((i - c + len) >  -1 ? args[i - c + len] : null);
      }
      args.length = c;
   }
};

main(1); // only calling main with one argument, which therefore needs to be the last one.

*** 是问题行,应该是“null null 1”以匹配重新分配的参数对象。

参数对象根据我的需要进行更改,将 main 调用的值“1”移动到最后一个参数。但是,在我移动参数对象后,映射到参数的变量名称不会发生更改(请参阅最后一个标有 *** 的 console.log)。这需要为 null null 1 以匹配更改的参数对象)。

如何让 shiftArgs 函数重新分配变量 a、b 和 c 以匹配参数对象?

最佳答案

你不想像这样搞乱参数对象。参数变量映射到它被认为是有问题的,它也不会在严格模式下工作。

最好使用函数装饰器来做这样的事情:

function shiftArgs(fn, c) {
    return function() {
        var lastIdx = arguments.length; 
        if (arguments.length < c)
            for (var i = c-1; i >= 0; i--)
                arguments[i] = ((i - c + lastIdx) >  -1 ? arguments[i - c + lastIdx] : null);
        arguments.length = c;
        return fn.apply(this, arguments);
    };
}

var main = shiftArgs(function(a, b, c) {
    console.log(a, b, c); // null null 1
}, 3);

关于javascript - 如何将函数的参数重新分配回原始参数名称?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28618818/

相关文章:

javascript - 比较 Javascript 中的类型

javascript - 输入文本后如何自动加载新页面

java - System 类中的方法导出不能应用于给定类型

perl - 符号表:删除条目

perl - 如何在 Perl 中访问名称包含在变量中的常量?

javascript - 在 Promise .then 中无法访问 $scope

javascript - 从快速排序中删除递归

java - 批量向java函数传递参数

Python 函数相当于 * 来扩展参数?

python - 为什么 exec() 中的符号定义语句有时对本地符号表没有影响?