JS中arguments的使用示例

 更新时间:2023年05月29日 09:53:48   作者:施主来了  
本文主要介绍了JS中arguments的使用示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

脚本之家 / 编程助手:解决程序员“几乎”所有问题!
脚本之家官方知识库 → 点击立即使用

在 JavaScript 中,arguments 是一个特殊的对象,它代表了函数调用时传递的参数列表。它可以在函数内部访问,用于获取传递给函数的实际参数值。
arguments 对象包含了函数调用时传递的所有参数,无论是否在函数定义时明确声明这些参数。它是一个类数组对象,可以通过索引访问其中的参数值。可以使用 arguments.length 属性获取传递的参数个数。

下面是关于 arguments 对象的一些示例:

arguments 对象中的参数是按照函数调用时的顺序进行存储的,可以通过索引访问它们。

1
2
3
4
5
function exampleFunc(a, b, c) {
  console.log(arguments[0]); // 访问第一个参数
  console.log(arguments[1]); // 访问第二个参数
}
exampleFunc(1, 2, 3); // 1,2

arguments 对象的长度(即 arguments.length)表示传递给函数的参数个数。

1
2
3
4
function exampleFunc() {
  console.log(arguments.length); // 参数个数
}
exampleFunc(1, 2, 3); // 3

arguments 对象与函数的形参之间存在联系,它们是相互关联的。当传递的参数个数多于形参个数时,可以通过 arguments 对象访问超出形参列表的参数值。

1
2
3
4
5
6
function exampleFunc(a, b) {
  console.log(a); // 访问第一个形参
  console.log(b); // 访问第二个形参
  console.log(arguments[2]); // 访问第三个参数
}
exampleFunc(1, 2, 3); // 1,2,3

除此之外,还有一些关于 arguments 对象的特性和使用方式:

与剩余参数结合使用:可以使用剩余参数语法与 arguments 对象结合使用,以便同时获取所有参数和访问超出形参列表的参数。

1
2
3
4
5
6
function exampleFunc(a, b, ...rest) {
  console.log(a); // 1
  console.log(b); // 2
  console.log(rest[0]); // 3
}
exampleFunc(1, 2, 3);

在上面的例子中,a 和 b 是正常的形参,而 ...rest 则是剩余参数语法,它将剩余的参数作为数组存储在 rest 变量中,其中包括超出形参列表的参数。callee 属性:arguments 对象具有一个特殊的属性 callee,它是一个指向当前正在执行的函数的引用。这在递归和匿名函数中特别有用。

1
2
3
4
5
6
7
8
9
function factorial(n) {
  if (n <= 1) {
    return 1;
  } else {
    return n * arguments.callee(n - 1);
  }
}
const result = factorial(5); // 递归计算阶乘
console.log(result); // 120

在上述示例中,factorial 函数通过调用 arguments.callee 实现了自身的递归调用,而不是使用函数名 factorial。这样可以确保即使在匿名函数中也能正确调用函数。

需要注意的是,arguments 对象并不是一个真正的数组,它是一个类数组对象。尽管它具有类似于数组的索引访问和 length 属性,但它没有数组原型上的方法,如 forEach()、map() 等。如果需要对 arguments 对象应用数组方法,可以将其转换为一个真正的数组,例如通过使用 Array.from() 或 Array.prototype.slice.call() 来转换。

随着es6的广泛使用,使用 arguments 对象的方式越来越少见,现在的开发更倾向于使用剩余参数、默认参数或解构赋值来处理函数参数,以提供更清晰、更灵活的语法和功能。尽量避免在新代码中使用 arguments 对象,除非有特定的需求。

到此这篇关于JS中arguments的使用示例的文章就介绍到这了,更多相关JS arguments内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

蓄力AI

微信公众号搜索 “ 脚本之家 ” ,选择关注

程序猿的那些事、送书等活动等着你

原文链接:https://juejin.cn/post/7238254724863000634

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若内容造成侵权/违法违规/事实不符,请将相关资料发送至 reterry123@163.com 进行投诉反馈,一经查实,立即处理!

相关文章

  • PHP捕捉异常中断的方法

    PHP捕捉异常中断的方法

    相信每位PHP程序员都知道,当PHP程序出现异常情况,如出现致命错误、超时或者不可知的逻辑错误导致程序中断,这个时候就可以用 register_shutdown_function进行异常处理。下面本文给出了详细的示例代码,有需要的朋友们下面来一起看看吧。
    2016-10-10
  • JS设置cookie、读取cookie

    JS设置cookie、读取cookie

    js设置cookie有很多种方法,包括JS设置cookie、读取cookie,工作中常会用到!下面是详细代码,感兴趣的小伙伴们可以参考一下
    2016-02-02
  • 聊聊JavaScript中的try...catch使用小技巧

    聊聊JavaScript中的try...catch使用小技巧

    作为一名web前端工程师,JavaScript中的try...catch是我们常用的特性之一,用于处理代码中可能出现的错误,本文小编将和大家一起聊聊JavaScript中的try...catch使用小技巧,需要的朋友可以参考下
    2023-11-11
  • 微信小程序换肤功能实现代码(思路详解)

    微信小程序换肤功能实现代码(思路详解)

    这篇文章主要介绍了微信小程序换肤功能实现代码,本文通过示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-08-08
  • javascript实现不同颜色Tab标签切换效果

    javascript实现不同颜色Tab标签切换效果

    这篇文章主要为大家详细介绍了javascript实现不同颜色Tab标签切换效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-04-04
  • 使用openSpeDiv方法实现Ecshop登录弹窗框效果

    使用openSpeDiv方法实现Ecshop登录弹窗框效果

    在ECSHOP的目录/JS/common.js中有一个openSpeDiv方法是实现ECSHOP的弹窗效果的。接下来通过本文给大家分享使用openSpeDiv方法实现Ecshop登录弹窗框效果,需要的朋友参考下
    2017-03-03
  • 原生JS实现点击数字小游戏

    原生JS实现点击数字小游戏

    这篇文章主要为大家详细介绍了原生JS实现点击数字小游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-04-04
  • JavaScript命令模式原理与用法实例详解

    JavaScript命令模式原理与用法实例详解

    这篇文章主要介绍了JavaScript命令模式原理与用法,结合实例形式详细分析了JavaScript命令模式基本概念、原理、用法及操作注意事项,需要的朋友可以参考下
    2020-03-03
  • javascript IE中的DOM ready应用技巧

    javascript IE中的DOM ready应用技巧

    当我们想在页面加载之后执行某个函数,肯定会想到onload了 但onload在浏览器看来,就是页面上的东西全部都加载完毕后才能发生,但那就为时已晚了。
    2008-07-07
  • js点击图片实现查看大图简单方法

    js点击图片实现查看大图简单方法

    今天开发的时候,遇到要点击缩略图之后显示图片的大图查看,所以本文给大家分享下,这篇文章主要给大家介绍了关于js点击图片实现查看大图的简单方法,需要的朋友可以参考下
    2023-06-06

最新评论