方法参数 默认值_【ES6】函数的默认值

35a96c935dfce0b78aab58205d8ec07d.png

函数默认值

ES6 之前,不能直接为函数的参数指定默认值,只能采用变通的方法。

function log(x, y) {
  y = y || '哈喽';
  console.log(x, y);
}
log('Hello') // Hello World
log('Hello', '你好') // Hello China

1eaa756ad342f7802a6412fdd328d448.png

这里可以看到,检查函数log的参数y有没有赋值,如果没有,则指定默认值为‘哈喽’。

这种写法的缺点在于,如果参数y赋值了,但是对应的布尔值为false,则该赋值不起作用。就像下面代码,参数y等于空字符,结果被改为默认值。

function log(x, y) {
  y = y || '哈喽';
  console.log(x, y);
}
log('Hello', '') // Hello 哈喽

0f4db8628fb346c5c5dd47cadff29917.png

为了避免这个问题,通常需要先判断一下参数y是否被赋值,如果没有,再等于默认值。

if (typeof y === 'undefined') {
  y = '哈喽';
}

ES6的写法

直接写在参数定义的后面

var a = prompt()
function log(x, y = '哈喽') {
  console.log(x, y);
}

log('Hello') // Hello 哈喽
log('Hello', a) // Hello 哈喽
log('Hello', a) 

4e958d1ed1e235d6bccac663b63ca276.gif

这里可以看到 参数y等于空字符,结果也没有被改。

ES6 的写法比 ES5 简洁许多,而且非常自然

ES6里面参数变量是默认声明的,所以不能用letconst再次声明。

function foo(x = 5) {
  let x = 1; // error
  const x = 2; // error
}

2f6f034ad58669c2c65d5f31a17d731e.png

上面代码中,参数变量x是默认声明的,在函数体中,不能用letconst再次声明,否则会报错。

使用参数默认值时,函数不能有同名参数。

// 不报错
function foo(x, x, y) {
  // ...
}

// 报错
function foo(x, x, y = 1) {
  // ...
}

8de499c98363390eca3fbd9decc8d9de.png

这里可以看到,有同名函数的话也会报错

今天就到这里了!

e8e3857a22cf82885b168058c35f50df.gif
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值