ES6 之字符串、数值和布尔值的解构赋值

字符串的解构赋值

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

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

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

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

数值和布尔值的解构赋值

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

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

本文转载自:http://es6.ruanyifeng.com/#docs/destructuring#字符串的解构赋值 并进行整理

除特殊说明外本人博客均属原创,转载请注明出处:http://blog.johnhan.cn/blog_1014.html
鄂ICP备17018604号-1  鄂公网安备42060702000030号