## 1\. 字符串
字符串也可以解构赋值。这是因为此时,字符串被转换成了一个类似数组的对象。
~~~javascript
const [a, b, c, d, e] = 'hello';
a // "h"
b // "e"
c // "l"
d // "l"
e // "o"
~~~
类似数组的对象都有一个`length`属性,因此还可以对这个属性解构赋值。
~~~javascript
let {length : len} = 'hello';
len // 5
~~~
## 2\. 数值和布尔值
解构赋值时,如果等号右边是数值和布尔值,则会先转为对象。
~~~javascript
let {toString: s} = 123;
s === Number.prototype.toString // true
let {toString: s} = true;
s === Boolean.prototype.toString // true
~~~
上面代码中,数值和布尔值的包装对象都有`toString`属性,因此变量`s`都能取到值。
解构赋值的规则是,只要等号右边的值不是对象或数组,就先将其转为对象。由于`undefined`和`null`无法转为对象,所以对它们进行解构赋值,都会报错。
## 3. 函数参数