在创建一个函数并调用时可以传入一些参数或变量,调用底不过一个被调用的函数函数究竟有多少可用的参数呢? 函数中的可用变量 以下通过一个例子来检查在调用函数时会有哪些变量和参数,在这里可以在浏览器的时到少“无痕窗口”中直接运行这段代码(无痕窗口能避免浏览器插件影响运行)。 注意:这里仅仅针对传统函数,传多参数箭头函数的调用底运行变量与传统函数不同,在此不做讨论。函数 在运行时切换到 Source 页,并用 Chrome 的传多参数 JavaScript 调试模式来进行验证。 接下来进入到 aFunction 的调用底函数中时,可以切换到 console.log(...) 一这行停下来,函数结果如下: 接下来会看到 Scope 表示当前函数的时到少作用域,作用域中可调用的传多参数变量也会按顺序列出,在这里可以看到的调用底变量和参数包含: 以上五个变量中,前两个就属于在调用时传入的变量,本文也会着重介绍它们的特点。 参数的性质 参数是由主调函数传入的变量,相对于其它编程语言来说, JS 传递参数的限制更少,任何值都可以作为参数,也正是因为如此,初次接触或从其它语言转过来的会有许多不熟悉的地方,以下是一些常见的问题: 1. 参数名称是在函数声明时定义的 这是一个非常基础的问题,云服务器刚开始学编程的新手经常会把参数名搞混,误以为调用时传入的参数名就是在函数内使用的名称,比如下面的例子输出的值是什么? A. a,b,c,undefined B. d,c,b,a 函数参数的名称是在定义函数时就已经确定了的,如下图:参数取值是按顺序带入,并且不会受到调用时名称的影响。 简单的结论: 2. ES6 的参数默认值 如果已经定义了参数,但却没有传入,那么函数内取到的值为 undefined ,如果遇到这样的情况,代码就必须加入许多的容错机制,云南idc服务商以避免 undefined 造的错误。 ES6 中新增了“参数默认值”可预先给特定参数设置默认值,除了避免 undefined 所造成的错误外,还可以增加使用函数的弹性。 下面的例子通过简单的语法就可加上“参数默认值”,当外部没有传入值时就会使用默认值。 3. arguments 如果无法确认所传入参数的数量该怎么办? 这种情况在项目开发中比较少见,但在开发框架、函数库时却很常见,前面所提到的 “如果未定义,但有更多的参数传入则需要使用其它方式取值”的情况 ,就会用到下面将要介绍的 arguments 参数(ES6 中有更好的方法)。 所有的传统函数都有 arguments 参数(注意:箭头函数没有),不需要另外定义即可直接调用,且作用域仅限于本函数中。 arguments 的结构本质上是一个数组,其中会包含调用时传入的所有值,在不确定传入参数的数量时,是一个很好用的方法。 4. ES6 剩余参数 因为 arguments 有一些缺点,如: 所以 ES6 新增了剩余参数语法,可在定义参数时直接传入剩余的未定的参数,语法如下: 结果和前面的例子类似,但会是纯数组的方式展现,并且只会获取未定义的参数内容(a 会被跳过)。另外,箭头函数是可以使用剩余参数的。 5. 函数也可作为参数 函数除了可以传入纯值、数组和对象外,还可以把函数作为参数,使函数运行时更加丰富而且——呃。。。复杂。 下面的例子中,在调用 functionB 时,还可以传入另一个函数作为参数,这种手段叫回调函数( callback function)。 你自己可以试着看看其中的参数是如何传递的。 JavaScript可将函数作为参数传递,这样的特性也称为“一级函数”(First-class Function),在以后的文章中我会更深入的介绍。