变量的解析赋值(2)

请注意,本文编写于 1672 天前,最后修改于 1669 天前,其中某些信息可能已经过时。

默认值

解构赋值允许指定默认值

let [foo = true] = [];
foo //true
let[x,y = 'b'] = ['a'];//x = 'a',y = 'b'
let[x,y='b'] = ['a',undefined];//x='a',y='b'

注意,ES6内部使用严格相等运算符(===),判断一个位置是否有值.所以,只有当一个数组成员严格等于undefined,默认值才会生效.

let [x = 1]=[undefined];
x//1
let [x = 1]=[null];
x//null

上面代码中,如果一个数组成员是null,默认值就不会生效,因为null不严格等于undefined.

如果默认值是一个表达式,那么这个表达式是惰性求值的,即只有在用到的时候,才会求值.

function f(){
    console.log('aaa')
}

上面的代码中,因为x能取到值,所以函数f根本不会执行.上面的代码其实等价于下面的代码.

let x;
if([1][0]===undefined){
   x=f();
}else{
 x = [1][0];
}

默认值可以引用解构赋值的其他变量,但该变量必须已经声明.

let [x = 1,y = x] = [];//x=1,y=1
let[x = 1,y = x] = [2];//x=2,y=2
let[x = 1,y = x] = [1,2]//x=1,y=2
let[x = y,y = 1]=[];//ReferenceError:y is not defined

上面最后一个表达式之所以会报错,是因为xy做默认值时,y还没有声明.

添加新评论

评论列表