![35a96c935dfce0b78aab58205d8ec07d.png](https://img-blog.csdnimg.cn/img_convert/35a96c935dfce0b78aab58205d8ec07d.png)
函数默认值
ES6 之前,不能直接为函数的参数指定默认值,只能采用变通的方法。
function log(x, y) {
y = y || '哈喽';
console.log(x, y);
}
log('Hello') // Hello World
log('Hello', '你好') // Hello China
![1eaa756ad342f7802a6412fdd328d448.png](https://img-blog.csdnimg.cn/img_convert/1eaa756ad342f7802a6412fdd328d448.png)
这里可以看到,检查函数log
的参数y
有没有赋值,如果没有,则指定默认值为‘哈喽’。
这种写法的缺点在于,如果参数y
赋值了,但是对应的布尔值为false
,则该赋值不起作用。就像下面代码,参数y
等于空字符,结果被改为默认值。
function log(x, y) {
y = y || '哈喽';
console.log(x, y);
}
log('Hello', '') // Hello 哈喽
![0f4db8628fb346c5c5dd47cadff29917.png](https://img-blog.csdnimg.cn/img_convert/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](https://img-blog.csdnimg.cn/img_convert/4e958d1ed1e235d6bccac663b63ca276.gif)
这里可以看到 参数y等于空字符,结果也没有被改。
ES6 的写法比 ES5 简洁许多,而且非常自然
ES6里面参数变量是默认声明的,所以不能用let
或const
再次声明。
function foo(x = 5) {
let x = 1; // error
const x = 2; // error
}
![2f6f034ad58669c2c65d5f31a17d731e.png](https://img-blog.csdnimg.cn/img_convert/2f6f034ad58669c2c65d5f31a17d731e.png)
上面代码中,参数变量x
是默认声明的,在函数体中,不能用let
或const
再次声明,否则会报错。
使用参数默认值时,函数不能有同名参数。
// 不报错
function foo(x, x, y) {
// ...
}
// 报错
function foo(x, x, y = 1) {
// ...
}
![8de499c98363390eca3fbd9decc8d9de.png](https://img-blog.csdnimg.cn/img_convert/8de499c98363390eca3fbd9decc8d9de.png)
这里可以看到,有同名函数的话也会报错
今天就到这里了!
![e8e3857a22cf82885b168058c35f50df.gif](https://img-blog.csdnimg.cn/img_convert/e8e3857a22cf82885b168058c35f50df.gif)