JavaScript 解构赋值详解,一文通其意。

JavaScript 解构赋值详解

值是 JavaScript 中一种非常强大的语法,能够轻松地从数组或对象中提取值并将其赋给变量。它使得代码更加简洁,尤其在处理复杂的数据结构时,能显著提高代码的可读性和效率。

数组解构赋值。

解构赋

1️ 基本的数组解构

ini 复制代码
const num1 = [1, 3, 5, 7];
let [a, b, c, d] = num1;  // 声明同时解构  
console.log(a, b, c, d); // 输出: 1 3 5 7
  • 解释:通过数组的顺序解构,将数组中的元素按顺序赋值给变量。

2️ 解构赋值与默认值

scss 复制代码
const num2 = ['xixi', 'linxi', 'xiaoxixi'];
let e, f, g;
[e, f, g] = num2;  // 赋值给 e, f, g
console.log(e, f, g); // 输出: xixi linxi xiaoxixi

[e, f, g = 'default'] = ['yueye', '5418y']; // 为 g 设置默认值
console.log(e, f, g); // 输出: yueye 5418y default
  • 解释 :当解构的变量缺少对应的值时,可以通过给变量设置默认值,防止 undefined 值。

###3️⃣ 使用剩余运算符获取多余的值

ini 复制代码
const num2 = ['xixi', 'linxi', 'xiaoxixi'];
let h, k;
[h, ...k] = num2;
console.log(h, k); // 输出: xixi ['linxi', 'xiaoxixi']
  • 解释 :使用剩余运算符 ... 将其余的值分配到一个新数组中,常用于提取数组前几个元素。

4️ 交换变量的值

ini 复制代码
let x = 10;
let y = 20;
console.log(x, y); // 输出: 10 20
[x, y] = [y, x];  // 快速交换两个变量的值
console.log(x, y); // 输出: 20 10
  • 解释:通过解构赋值,快速交换两个变量的值,不需要额外的中间变量。

5️ 二维数组解构赋值

scss 复制代码
const arr3 = [['linxi', '18', 'female'], ['xixi', '17', 'female']];
let [[name, age, gender], obj] = arr3;
console.log(name, age, gender, obj); // 输出: linxi 18 female ['xixi', '17', 'female']

// 循环遍历二维数组
for (let value1 of arr3) {
  console.log(value1);
  for (let value2 of value1) {
    console.log(value2);
  }
}
  • 解释:数组中的元素如果还是数组,可以继续用解构赋值提取内部数据。

对象解构赋值

1️ 基本的对象解构

ini 复制代码
const person = { name: 'linxi', age: 18, gender: 'female' };
let { name, age, gender } = person;
console.log(name, age, gender); // 输出: linxi 18 female
  • 解释:直接通过对象的属性名进行解构,自动将属性值赋给同名的变量。

2️ 对象属性名与变量名不一致时的解构

ini 复制代码
const person1 = { name1: 'lin', age1: 18, gender1: 'female' };
let name1, age1, gender1;
({ name1, age1, gender1 } = person1); // 使用圆括号包裹解构赋值
console.log(name1, age1, gender1); // 输出: lin 18 female
  • 解释:当对象的属性名与变量名不一致时,必须使用圆括号包裹解构,否则会报错。

3️ 为解构的属性赋予别名

javascript 复制代码
let { name: a, age: b, gender: c } = person; // 为 name, age, gender 赋予别名
console.log(a, b, c); // 输出: linxi 18 female
  • 解释 :通过 : 为属性赋予别名,将对象的属性值赋给新的变量名。

解构赋值的注意事项

  1. 对象解构时,属性名必须匹配
    如果解构对象时,变量名和对象属性名不一致,会导致 undefined
  2. 解构的顺序要与数组的顺序匹配
    数组解构时,变量会按顺序获取数组中的元素,顺序不匹配会导致 undefined
  3. 默认值的使用
    对于 undefined 的值,可以通过默认值来避免报错或返回 undefined
  4. 结合剩余运算符处理不定长数组
    在解构数组时,使用剩余运算符可以收集其余的元素,灵活应对不定长的数组。

总结

解构赋值是 JavaScript 中的一项强大特性,能够通过简洁的语法对数组和对象进行赋值操作。无论是交换变量值、处理多维数组,还是给属性赋予别名,解构赋值都能提供极大的便利。通过合理使用解构赋值,可以使代码更加清晰、简洁,并减少冗余。

相关推荐
Yeats_Liao3 小时前
Go Web 编程快速入门 02 - 认识 net/http 与 Handler 接口
前端·http·golang
金梦人生3 小时前
🔥Knife4j vs Swagger:Node.js 开发者的API文档革命!
前端·node.js
东华帝君3 小时前
react 虚拟滚动列表的实现 —— 固定高度
前端
Larcher3 小时前
n8n 入门笔记:用零代码工作流自动化重塑效率边界
前端·openai
林希_Rachel_傻希希3 小时前
正则表达式捕获组与全局匹配
前端·javascript
前端赵哈哈3 小时前
那个让我熬夜三天的 “小数点”:一次 URL 踩坑记
前端·chrome·http
karshey3 小时前
【vue】NoticeBar:滚动通知栏组件手动实现(内容、速度、循环间隔可配置)
前端·javascript·vue.js
醉方休3 小时前
React 官方推荐使用 Vite
前端·react.js·前端框架
花菜会噎住3 小时前
Vue3 路由配置和使用与讲解(超级详细)
开发语言·javascript·ecmascript·路由·router