美文网首页
031|JavaScript arguments对象

031|JavaScript arguments对象

作者: 中年小钢炮 | 来源:发表于2017-05-21 15:58 被阅读37次

上一节中,我们使用默认参数特性处理了调用者未传参数的问题。

这一节中,我们将要处理调用者传递了参数,但函数未定义参数的情况。

使用arguments访问参数

我们先来分析一下以下代码:

function sayHi()
{
    console.log("Hello somebody!")
}

sayHi("James")

上述代码中,sayHi()函数并未定义任何一个参数,但调用者却传递了参数"James"。这个脚本会报错吗?我们尝试运行一下:

脚本运行结果

可以看到,上面脚本并无任何异常,而是正常地输出了"Hello somebody!"。

由上例可知,调用者可不管不顾函数到底定义了多少参数,可以随意填写参数。

在函数体内, 有一个变量,存储着传递给当前函数的所有参数,它就是arguments。arguments是一个数组,依次存储着调用者向函数传递的参数。
我们通过将上述代码改造一下来了解arguments变量:

function sayHi()
{
    console.log("Hello "+arguments[0]+"!") // 通过arguments[0]引用第一个参数
}

sayHi("James")

上述代码中,使用arguments[0]引用了第一个参数James。所以程序最终输出如下:

运行结果

所以,通过arguments对象能够引用调用者传递的参数。

使用arguments解决不定长参数的问题

arguments的一个重要作用是解决变长参数的问题。

现在,你需要写一个函数,它能将传递进来的参数全部打印出来。例如:
···
function sayHi(){
// 你需要实现这个函数
}
sayHi("David") // 1个参数
sayHi("David", "James") // 2个参数
...
sayHi("David", "James", ... , "Lucy") // N个参数
···

函数定义时,参数个数是固定的,而上述问题中,调用者传递参数是变动的。所以普通函数参数无法解决上述问题。这时就到arguments发挥作用的时候了。

函数剩余参数也能解决上述问题。后续课程中将会介绍 。

让我们来看一上arguments的解决方案:

function sayHi()
{
  for (var i = 0; i < arguments.length; i++)
  {
      console.log("Hello "+arguments[i]+"!")
  }
}
sayHi("David") // 1个参数
sayHi("David", "James") // 2个参数
sayHi("David", "James", "Lucy") // N个参数

我们来看看输出结果 :

变长参数问题

可以看到,通过使用arguments参数,我们成功解决了变长参数问题。

好了,这一节就讲到这里。今天,你学到了一个非常实用的技巧!

什么是匿名函数?什么是函数调用栈?什么是函数剩余参数?

请继续关注我的课程,我将在后续课程中为大家解答上述问题。

想学计算机技术吗?需要1对1专业级导师指导吗?想要团队陪你一起进步吗?欢迎加我为好友!

我的微信

相关文章

  • 031|JavaScript arguments对象

    上一节中,我们使用默认参数特性处理了调用者未传参数的问题。 这一节中,我们将要处理调用者传递了参数,但函数未定义参...

  • JS中的arguments对象

    在JavaScript中,arguments是什么? 在JavaScript中,arguments是对象的一个特殊...

  • JavaScript arguments对象

    1、在JavaScript中,arguments对象是比较特别的一个对象,实际上是当前函数的一个内置属性。argu...

  • JavaScript中的arguments对象

    JavaScript中的arguments对象 arguments 是一个类似数组的对象, 对应于传递给函数的参数...

  • Javascript中对arguments的一点点理解

    Javascript中的arguments对象 实参和形参的同步性 实参是存储在arguments对象中,argu...

  • JS-day04-4.27

    arguments的使用 JavaScript中,arguments对象是比较特别的一个对象,实际上是当前函数的一...

  • 02-JavaScript

    一、基础 1.函数的arguments 其实Javascript并没有重载函数的功能,但是Arguments对象能...

  • 2018-06-06

    JavaScript函数 1. arguments对象 — 函数的实参参数集合 // 循环...

  • Javascript arguments对象详解

    今天我们来看看arguments对象及属性。arguments对象不能显式创建,arguments对象只有函数开始...

  • 将 arguments 转为真正的数组的方法

    出处 函数 - JavaScript 教程 - 网道 ---- arguments-对象 代码 slice方法 逐...

网友评论

      本文标题:031|JavaScript arguments对象

      本文链接:https://www.haomeiwen.com/subject/owtvxxtx.html