JS中的argument,你真的会用吗

也许在平常的js编写中,我们很少使用argument,但不妨碍我们了解它的强大之处,在本文我将举出各种例子带大家感受它为方法实现带来的便利。

先简单介绍一下argument

arguments是一个类数组对象,它自动出现在每一个函数内部,包含了调用该函数时传入的所有参数。尽管它看起来像数组,但实际上并不是真正的数组,当我们调用Object.prototype.toString.call()时,返回的值为[object Arguments]。作为一个类数组,它拥有数组的.length属性和索引访问能力,但是如forEachmap等方法它是不拥有的。

使用场景

这是一段 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能够访问到其外部作用域中的变量和对象,包括 outerFunctionarguments对象,所以这里实际上是访问并打印了外部函数 outerFunctionarguments

  • 箭头函数:箭头函数不绑定自己的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, 3innerArrowFunction,但由于箭头函数没有自己的 arguments,它仍然访问的是外部 outerArrowFunctionarguments

结语

本文的精髓在于最后一部分"要注意的地方 ",如有略过的掘友建议回去看一遍。虽然rest运算符的出现让arguments的使用不如往昔那般频繁,但它依然是每位JavaScript开发者知识体系中不可或缺的一环。

相关推荐
无限大.2 小时前
前端知识速记:节流与防抖
前端
十八朵郁金香2 小时前
【VUE案例练习】前端vue2+element-ui,后端nodo+express实现‘‘文件上传/删除‘‘功能
前端·javascript·vue.js
学问小小谢2 小时前
第26节课:内容安全策略(CSP)—构建安全网页的防御盾
运维·服务器·前端·网络·学习·安全
LCG元3 小时前
Vue.js组件开发-实现全屏图片文字缩放切换特效
前端·javascript·vue.js
还是鼠鼠4 小时前
图书管理系统 Axios 源码__新增图书
前端·javascript·vscode·ajax·前端框架·node.js·bootstrap
还是鼠鼠7 小时前
图书管理系统 Axios 源码 __删除图书功能
前端·javascript·vscode·ajax·前端框架·node.js·bootstrap
轻口味7 小时前
Vue.js `Suspense` 和异步组件加载
前端·javascript·vue.js
m0_zj8 小时前
8.[前端开发-CSS]Day08-图形-字体-字体图标-元素定位
前端·css
还是鼠鼠9 小时前
图书管理系统 Axios 源码__编辑图书
前端·javascript·vscode·ajax·前端框架
北极象9 小时前
vue3中el-input无法获得焦点的问题
前端·javascript·vue.js