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开发者知识体系中不可或缺的一环。

相关推荐
KaMeidebaby1 小时前
卡梅德生物技术快报|骆驼纳米抗体:从原核表达、高通量测序到分子对接全流程实现
前端·数据库·其他·百度·新浪微博
子兮曰3 小时前
Node.js v26.1.0 深度解读:FFI、后量子密码与调试器的进化
前端·后端·node.js
测试员周周3 小时前
【Appium 系列】第06节-页面对象实现 — LoginPage 实战
开发语言·前端·人工智能·python·功能测试·appium·测试用例
西洼工作室4 小时前
前端直传OSS服务端签名(Policy+Signature)/STS临时凭证
前端·文件上传·oss
你很易烊千玺5 小时前
日常练习-数组 字符串常用的场景
前端·javascript·字符串·数组
weixin199701080166 小时前
[特殊字符] RESTful API 接口规范详解:构建高效、可扩展的 Web 服务(附 Python 源码)
前端·python·restful
存在的五月雨6 小时前
Vue3项目一些语法
前端·javascript·react.js
nashane6 小时前
HarmonyOS 6学习:Web组件同层渲染事件处理与智能长截图实现
前端·学习·harmonyos·harmonyos 5
大家的林语冰6 小时前
Node 2026 发布,JS 三大新功能上线,最后一个奇偶版本
前端·javascript·node.js