Assignmentdestructuringandoperatorprecedence
创始人
2024-09-20 18:00:17
0

Assignment destructuring是ES6引入的一种新特性,它允许我们通过一种语法形式从数组或对象中提取值并将其赋值给变量。

假设我们有一个数组,我们想将其第一项和第二项分别赋值给变量a和b:

const arr = [1, 2, 3, 4, 5];
const [a, b] = arr;
console.log(a); // 1
console.log(b); // 2

我们还可以使用默认值来避免undefined情况:

const [a = 0, b = 0, c = 0] = [1, 2];
console.log(a, b, c); // 1 2 0

同时,我们可以在函数参数中使用assignment destructuring:

function foo({ a, b }) {
  console.log(a, b);
}
foo({ a: 1, b: 2 }); // 1 2

在使用assignment destructuring时,需要注意运算符优先级。例如:

const obj = { a: 1, b: 2 };
const a = obj.a || 0; // 1
const b = obj.b || 0; // 0

这里的问题在于 || 运算符的优先级比 = 运算符的优先级高,所以变量a不会被赋值为0。解决方法是给整个表达式加上括号:

const obj = { a: 1, b: 2 };
const a = (obj.a || 0); // 1
const b = (obj.b || 0); // 2

相关内容

热门资讯

4分钟外挂!边锋微信小程序,四... 4分钟外挂!边锋微信小程序,四川途游辅助软件下载,2025新版(有挂方式)-哔哩哔哩1、下载好四川途...
第4分钟普及!家乡大二辅助,四... 第4分钟普及!家乡大二辅助,四川游戏家园通用辅助(其实有挂)-哔哩哔哩1、四川游戏家园通用辅助系统规...
第四分钟外挂!皮皮跑胡子修改器... 第四分钟外挂!皮皮跑胡子修改器,友友联盟免费辅助器,安装教程(有挂方法)-哔哩哔哩1、进入到友友联盟...
第8分钟详情!方片十三张源码,... 第8分钟详情!方片十三张源码,河洛杠次脚本开发(一贯有挂)-哔哩哔哩1)河洛杠次脚本开发辅助挂:进一...
1分钟外挂!传送屋激k有挂吗,... 1分钟外挂!传送屋激k有挂吗,兴动互娱辅助工具,解密教程(有挂分析)-哔哩哔哩1、超多福利:超高返利...
第6分钟解谜!山西扣点点智能辅... 第6分钟解谜!山西扣点点智能辅助器软件,决战卡五星辅助(一直是真的挂)-哔哩哔哩1、玩家可以在山西扣...
第五分钟推荐!开心泉州免费辅助... 第五分钟推荐!开心泉州免费辅助器,友友联盟免费辅助器(真是真的有挂)-哔哩哔哩1、完成开心泉州免费辅...
六分钟外挂!指尖四川小程序辅助... 六分钟外挂!指尖四川小程序辅助,八闽福建辅助,微扑克教程(存在有挂)-哔哩哔哩暗藏猫腻,小编详细说明...
第4分钟必备!潮汕木虱辅助下载... 第4分钟必备!潮汕木虱辅助下载,天天飞小鸡辅助(一贯存在有挂)-哔哩哔哩1、操作简单,无需注册,只需...
七分钟外挂!浙江宝宝游戏辅助下... 七分钟外挂!浙江宝宝游戏辅助下载,小程序牵手跑的辅助,安装教程(有挂解惑)-哔哩哔哩1)浙江宝宝游戏...