也许在平常的js编写中,我们很少使用argument,但不妨碍我们了解它的强大之处,在本文我将举出各种例子带大家感受它为方法实现带来的便利。
先简单介绍一下argument
arguments
是一个类数组对象,它自动出现在每一个函数内部,包含了调用该函数时传入的所有参数。尽管它看起来像数组,但实际上并不是真正的数组,当我们调用Object.prototype.toString.call()
时,返回的值为[object Arguments]
。作为一个类数组,它拥有数组的.length
属性和索引访问能力,但是如forEach
、map
等方法它是不拥有的。
使用场景
这是一段 js代码,旨在让初学者更好地了解 argument。
js
function add(){
if(arguments.length>2){
return arguments;
}
}
console.log(add(1,2,3,4)) // 输出:[Arguments] { '0': 1, '1': 2, '2': 3, '3': 4 }
可见输出了一个类似于map的对象,实际前面的便是后面值的下标,可以像数组那样获取对应的值。
实现一个简单的求和方法
我们可以通过下标获取arguments中的值。
js
function sum() {
let total = 0;
for (let i = 0; i < arguments.length; i++) {
total += arguments[i];
}
return total;
}
console.log(sum(1, 2, 3)); // 输出 6
在这个方法中我们可以传任意个number,不受参数个数的约束。
扩展
对于上面的方法我们也可以运用rest运算符...
来实现
js
const add = (...args) => {
return args.reduce((a,b) => a+b,0)
}
console.log(add(1,2,3));
只需要一句代码就能够完成 。但看到这段代码可能就有掘友会问了,reduce()
是什么方法。
reduce()
这是mdn上对reduce()
的解释,可见它是属于数组的一个方法,常用于数组内元素的求和,rest运算符就是将输入的实参放在数组中。也正因为有了es6提出的rest运算符...
,argument就逐渐淡出我们的使用场景,它可以代替绝大多数argument的使用且更为简洁。
要注意的地方
arguments
对象是一个非常特殊的内置对象,它与函数的执行密切相关,所以在使用它的时候也有很多我们需要注意的地方。
- 性能方面: 频繁访问
arguments
可能会影响性能,尤其是在一些高性能要求的循环或密集计算场景中,因为访问arguments
比直接访问命名参数要慢。 - 函数嵌套: 当函数嵌套时该注意些什么呢?例如:
js
function outerFunction() {
console.log(arguments); // 正常显示传入的参数 innerFunction();
function innerFunction() {
console.log(arguments); // 同样可以访问到外层的arguments
}
}
outerFunction(1, 2, 3); // 输出两次相同的参数列表:[1, 2, 3]
arguments
同其它变量一样,遵守作用域规矩,innerFunction
被调用时,并没有直接向它传递任何参数。然而,innerFunction
能够访问到其外部作用域中的变量和对象,包括 outerFunction
的 arguments
对象,所以这里实际上是访问并打印了外部函数 outerFunction
的 arguments
。
- 箭头函数:箭头函数不绑定自己的arguments,它会捕获其所在上下文的arguments。例如:
js
function outerArrowFunction() {
console.log(arguments);
const innerArrowFunction = () => {
console.log(arguments);
};
innerArrowFunction(1,2,3);
}
outerArrowFunction(4,5,6); // 输出两次相同的参数列表:[4,5,6]
当调用 innerArrowFunction(1,2,3)
时,尽管你传递了参数 1, 2, 3
给 innerArrowFunction
,但由于箭头函数没有自己的 arguments
,它仍然访问的是外部 outerArrowFunction
的 arguments
。
结语
本文的精髓在于最后一部分"要注意的地方 ",如有略过的掘友建议回去看一遍。虽然rest运算符
的出现让arguments的使用不如往昔那般频繁,但它依然是每位JavaScript开发者知识体系中不可或缺的一环。