1、es6之前的函数参数默认值写法
1.1、使用短路或||
的写法
- 当y为空时,y判断为false ,走
||
右边的,所以y = 'world'
; - 当y不为空时,y判断为true,不需要再运行
||
右边的,所以y = y
javascript
function log(x, y) {
y = y || 'World';
console.log(x, y);
}
log('Hello') // Hello World
log('Hello', 'China') // Hello China
log('Hello', '') // Hello World
这中写法有个问题,就是第三种输出中的结果。当y值设置为""
时,走短路与运算判断为false,从而将默认值赋予了y。但是原本的意思是y的值就是""
,从而希望输出的是 Hello
。
1.2 添加typeof 判断是否为undefined
javascript
function log(x, y) {
if (typeof y === 'undefined') {
y = 'World';
}
console.log(x, y);
}
log('Hello') // Hello World
log('Hello', 'China') // Hello China
log('Hello', '') // Hello
这种写法可以避免1.1中y值为空串的情况。
2、es6写法
javascript
function log(x, y = 'World') {
console.log(x, y);
}
log('Hello') // Hello World
log('Hello', 'China') // Hello China
log('Hello', '') // Hello
上面是es6的写法,简单方便。
下面是解构赋值和函数默认值结合:
方法一是个解构变量设置默认值,二默认值生效的条件是对象属性值严格等于undefined。
方法二是设置对象的值,没有设置解构变量的默认值。
在没有参数和x y都有值的情况下,两者的结果一样。其他情况下两者有区别。
javascript
// 写法一
function m1({x = 0, y = 0} = {}) {
return [x, y];
}
// 写法二
function m2({x, y} = { x: 0, y: 0 }) {
return [x, y];
}
// 函数没有参数的情况
m1() // [0, 0]
m2() // [0, 0]
// x 和 y 都有值的情况
m1({x: 3, y: 8}) // [3, 8]
m2({x: 3, y: 8}) // [3, 8]
// x 有值,y 无值的情况
m1({x: 3}) // [3, 0]
m2({x: 3}) // [3, undefined]
// x 和 y 都无值的情况
m1({}) // [0, 0];
m2({}) // [undefined, undefined]
m1({z: 3}) // [0, 0]
m2({z: 3}) // [undefined, undefined]