欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

ES2015入门系列4-参数默认值

程序员文章站 2022-07-16 14:34:43
...

这个功能比较简单,但对于后端开发来说,会觉得会奇怪,参数默认值还需要特殊支持么?答案是肯定的,在ES5中, 参数是不可以指定默认值的,统一默认为 undefined, 如下代码:

function say(word) {
  word = word || '呵呵!';
  console.log(word);
}

console.log(say()); //呵呵!
console.log(say('哈哈!')); //哈哈!

没错,ES2015之前,我们只能这么来操作参数默认值,但是在ES2015中,就不再需要啦,就和普通的后端语言一样:

function say(word = '呵呵!') {
  console.log(word);
}

console.log(say()); //呵呵!
console.log(say('哈哈!')); //哈哈!

是不是就这么结束啦?当然不是,回到官方手册上,我们看到的是:

Callee-evaluated default parameter values.

参数默认值是被计算过的,意味着,我们可以写表达式,这个也是其他语言做不到的,看代码:

function defaultWord() {
  return '呵呵!';
}

function say(word = defaultWord()) {
  console.log(word);
}

console.log(say()); //呵呵!
console.log(say('哈哈!')); //哈哈!

什么叫evaluated, 其实也就是在应用默认值的时候,相当于JavaScript编译器使用eval计算一下,出来的结果当作默认值:

function say(word = eval('"呵呵!"')) {
  console.log(word);
}

function say(word = eval('defaultWord()')) {
  console.log(word);
}

还有:

Default parameters are available to later default parameters.

有默认值的参数,对其后面的参数可用,啥意思?看代码:

function renderScore(name, score = 100, description = (score === 100 ? '(好棒)' : '')) {
  console.log(name + '得分: ' + score + description);
}
renderScore('小明');
renderScore('小花', 80);
renderScore('小静', 100);
renderScore('小强', 90, '(加油哦!)');

结果为:

> 小明得分: 100(好棒)
> 小花得分: 80
> 小静得分: 100(好棒)
> 小强得分: 90(加油哦!)
有想要一起学习交流的朋友们,可以加我的前端群615496236,大家一起讨论,交流心得,这样也能少走弯路,学习前端能更加轻松愉快!!!
群里不定期分享案列资源特效源码。

这样,大家都应该清楚了吧?