看懂这个案例,了解ES6的解构赋值

本文深入探讨了ES6中字符串、数组和对象的解构赋值特性,包括其基本用法、特殊规则及常见错误,同时提供了丰富的示例代码帮助理解。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

// 字符串可以化成数组,数组又是特殊的对象 str => [] => {}
let str = "Hello ES6"; 

let {0: a} = str;  // 对象解构是根据属性
console.log(a); // H

let [b] = str;  // 数组解构是根据位置
console.log(b); // H

let {length: len} = str; // 因为str可以转成数组,而数组都有length属性,故可以解构
console.log(len);   // 9

// 注:解构赋值的规则是,只要等号右边的值不是对象或数组,就先将其转为对象。
let {toString: x} = len;
console.log(Number.prototype.toString) // true
let {toString: x} = (len === str.length);
console.log(x === Boolean.prototype.toString); // true

// 注: 由于undefined和null无法转为对象,所以对它们进行解构赋值,都会报错。
// let {x} = null;  // TypeError
// let {y} = undefined; // TypeError

想要更加详细的学习ES6语法,推荐网站: http://es6.ruanyifeng.com/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值