美文网首页
默认参数值

默认参数值

作者: 王康_Wang | 来源:发表于2017-02-06 15:35 被阅读0次

如果形参没有被传入对应的实参或者传入了 undefined ,则该形参会被赋一个默认值。

描述

在 JavaScript 里,函数参数默认是 undefined 。然而,在某些情况下设置一个不同的默认值可能是有需要的。默认参数可以帮助解决这个问题。
过去,一般的设置默认参数方法是在函数体测试参数是否为 undefined,如果是的话就设置为默认的值。例如:

function multiply(a, b) {
  b = typeof b !== 'undefined' ?  b : 1;

  return a*b;
}

multiply(5); // 5

有了默认参数,我们不需要再在函数体内做什么不必要的检查。现在你可以在函数头将b的默认值设置为1:

function multiply(a, b = 1) {
  return a*b;
}

multiply(5); // 5

注:即使显式地传入了undefined,参数的值也会去默认值。

调用时解析

在函数被调用时,参数默认值会被解析,所以不像 Python 中的例子,每次函数调用时都会创建一个新的参数对象。

function append(value, array = []) {
  array.push(value);
  return array;
}

append(1); //[1]
append(2); //[2], not [1, 2]

这个规则对于函数和变量也是适用的。

function callSomething(thing = something()) { return thing }

function something(){
  return "sth";
}

callSomething();  //sth
前置参数对于后面的默认参数是可见的

已经被声明的参数对于后面的默认参数是可见的。

function singularAutoPlural(singular, plural = singular+"s", 
                            rallyingCry = plural + " ATTACK!!!") {
  return [singular, plural, rallyingCry ]; 
}

//["Gecko","Geckos", "Geckos ATTACK!!!"]
singularAutoPlural("Gecko");

//["Fox","Foxes", "Foxes ATTACK!!!"]
singularAutoPlural("Fox","Foxes");

//["Deer", "Deer", "Deer ... change."]
singularAutoPlural("Deer", "Deer", "Deer peaceably and respectfully
   petition the government for positive change.")

以下这个例子近似模拟了一些比较简明的情况,并说明了特殊情况是怎么被处理的。

function go() {
  return ":P"
}

function withDefaults(a, b = 5, c = b, d = go(), e = this, 
                      f = arguments, g = this.value) {
  return [a,b,c,d,e,f,g];
}
function withoutDefaults(a, b, c, d, e, f, g){
  switch(arguments.length){
    case 0:
      a
    case 1:
      b = 5
    case 2:
      c = b
    case 3:
      d = go();
    case 4:
      e = this
    case 5:
      f = arguments
    case 6:
      g = this.value;
    default:
  }
  return [a,b,c,d,e,f,g];
}

withDefaults.call({value:"=^_^="});
// [undefined, 5, 5, ":P", {value:"=^_^="}, arguments, "=^_^="]

withoutDefaults.call({value:"=^_^="});
// [undefined, 5, 5, ":P", {value:"=^_^="}, arguments, "=^_^="]
函数嵌套定义

在函数体内的函数声明不能引用内部的默认参数,并会出现 ReferenceError 错误。默认参数总是会被首先执行,而在函数体内部的函数声明会在之后生效。
函数呃逆定义的闭包对于默认参数是不能引用的,如果引用会报错(“Reference Error”)。默认参数总是被最先解析,函数内部的声明会在这之后被解析。

// Doesn't work! Throws ReferenceError.
function f(a = go()) {
  function go(){return ":P"}
}
位于默认参数之后非默认参数
function f(x=1, y) { 
  return [x, y]; 
}

f(); // [1, undefined]

相关文章

  • ES6-参数处理

    默认参数值 函数默认参数允许在没有值或undefined被传入时使用默认形参。 传入undefined或者其它假值...

  • 《深入理解ES6》读书笔记——3.函数

    1)函数形参的默认值 (1)默认参数值 如果没味参数传入值,则为其提供一个初始值。在已经指定默认值的参数后可以继续...

  • 默认参数值

    如果形参没有被传入对应的实参或者传入了 undefined ,则该形参会被赋一个默认值。 描述 在 JavaScr...

  • swift 个人笔记(变量. 函数)

    常见的数据类型 初探 函数 返回元祖, 实现多返回值 参数标签 扩展 知识点. 默认参数值, 可变参数 输入输出参...

  • ES6形参默认值19-10-17

    1.形参的默认值 --当不传入形参的时候默认使用形参的默认值

  • Python函数默认参数设置

    在某些情况下,程序需要在定义函数时为一个或多个形参指定默认值,这样在调用函数时就可以省略为该形参传入参数值,而是直...

  • 形参默认值、Promise对象、async函数、class、字符

    形参默认值 *形参的默认值——————当不传入参数的时候默认使用形参里的默认值 function Point(x ...

  • Swift 函数 ③

    1 函数结构 形参只能是let,也必须是let 返回值可以是元祖,实现多返回值 参数标签 默认参数值在省略标签时。...

  • 2019-06-28

    形参默认值 形参的默认值:当不传入参数的时候使用形参的默认值(undefined) Promise对象 Promi...

  • 函数参数

    默认参数值 ES2015语法直接实现默认参数值: 默认参数特性还可以用在对象的方法中,而且默认值还是可以是对象的某...

网友评论

      本文标题:默认参数值

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