ES6字符串,数值,布尔值的结构赋值

ES6字符串,数值,布尔值的结构赋值

1.字符串的结构赋值

字符串也可以解构赋值,因为此时字符串被转换为一个类似数组的对象

const [a, b, c, d, e] = 'hello';
// a = "h"
// b = "e"
// c = "l"
// d = "l"
// e = "o"

类似数组的对象都有一个length属性,因此还可以对这个属性进行解构赋值

let { length: len } = "hello";
// len: 5

2.数值和布尔值的解构赋值

结构赋值时,如果等号右边是数值和布尔值,则会先转为对象

let {toString: s} = 123;
s === Number.prototype.toString  // true

let { toString: s} = true;
s === Boolean.prototype.toString // true
// 数值和布尔值得包装对象都有toString属性,因此变量s都能取到值

注意: 解构赋值的规则是,只要等号右边的值不是对象或数组,就先将其转换为对象,由于undefined和null无法转为对象,所以解构赋值时会报错

let {prop: x} = undefined;   // TypeError
let {prop: y} = null;   // TypeError
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值