ES6解构赋值详解;全面掌握:JavaScript解构赋值的终极指南
创始人
2024-09-24 19:36:00
0

目录

全面掌握:JavaScript解构赋值的终极指南

一、数组解构赋值

1、基本用法

2、跳过元素

3、剩余元素

4、默认值

二、对象解构赋值

1、基本用法

2、变量重命名

3、默认值

4、嵌套解构

三、复杂的嵌套结构解构

四、函数参数解构赋值

1、对象解构作为函数参数

2、带有默认值的函数参数解构

五、解构赋值中的交换变量

六、解构赋值与遍历

1、解构数组中的对象

七、结合 rest 运算符

八、处理函数返回的对象或数组

九、实际应用中的注意事项

1、属性不存在时的情况

2、深度解构可能导致错误

十、总结


作者:watermelo37

涉及领域:Vue、SpingBoot、Docker、LLM、python等

-----------------------------------------------------------------------------------

-------温柔地对待温柔的人,包容的三观就是最大的温柔。-------

-----------------------------------------------------------------------------------

全面掌握:JavaScript解构赋值的终极指南

        解构赋值(Destructuring Assignment)是 ES6(ECMAScript 2015) 引入的一种强大且灵活的语法,允许将数组或对象中的数据提取到变量中。它可以极大地简化从复杂数据结构中获取数据的过程。在以下内容中,我将详细解释解构赋值的语法及其在实践中的应用。

一、数组解构赋值

        数组解构赋值是基于数组元素的顺序,将数组中的值依次赋值给对应的变量。

1、基本用法

const arr = [10, 20, 30];  const [a, b, c] = arr;  console.log(a); // 输出: 10 console.log(b); // 输出: 20 console.log(c); // 输出: 30 

2、跳过元素

const arr = [10, 20, 30];  const [a, , c] = arr;  console.log(a); // 输出: 10 console.log(c); // 输出: 30 

3、剩余元素

        使用剩余运算符 (...) 获取数组中的其余元素(这里要注意区分剩余运算符和拓展运算符噢)。

const arr = [10, 20, 30, 40];  const [a, ...rest] = arr;  console.log(a);    // 输出: 10 console.log(rest); // 输出: [20, 30, 40] 

4、默认值

        当解构的数组没有足够的元素时,可以为变量提供默认值。

const arr = [10];  const [a, b = 20] = arr;  console.log(a); // 输出: 10 console.log(b); // 输出: 20 

二、对象解构赋值

        对象解构赋值是基于属性名的匹配,将对象属性的值赋给变量。

1、基本用法

const obj = { name: 'Alice', age: 25 };  const { name, age } = obj;  console.log(name); // 输出: Alice console.log(age);  // 输出: 25 

2、变量重命名

        可以将对象属性的值赋给一个新的变量名。

const obj = { name: 'Alice', age: 25 };  const { name: n, age: a } = obj;  console.log(n); // 输出: Alice console.log(a); // 输出: 25 

3、默认值

        如果对象中没有该属性,可以为变量提供默认值。

const obj = { name: 'Alice' };  const { name, age = 30 } = obj;  console.log(age); // 输出: 30 

4、嵌套解构

        可以解构嵌套的对象或数组。

const obj = {   user: {     name: 'Alice',     age: 25   } };  const { user: { name, age } } = obj;  console.log(name); // 输出: Alice console.log(age);  // 输出: 25 

三、复杂的嵌套结构解构

        解构可以处理复杂的数据结构,组合使用数组和对象的解构语法。

const data = {   id: 1,   name: 'John',   locations: [     {       city: 'New York',       state: 'NY'     },     {       city: 'San Francisco',       state: 'CA'     }   ] };  const {   name,   locations: [     { city: city1 },     { city: city2 }   ] } = data;  console.log(name);   // 输出: John console.log(city1);  // 输出: New York console.log(city2);  // 输出: San Francisco 

四、函数参数解构赋值

        在函数的参数中使用解构赋值,可以使函数更具可读性,特别是当参数是对象或数组时。

1、对象解构作为函数参数

function greet({ name, age }) {   console.log(`Hello, ${name}. You are ${age} years old.`); }  const person = { name: 'Alice', age: 25 };  greet(person); // 输出: Hello, Alice. You are 25 years old. 

2、带有默认值的函数参数解构

function greet({ name = 'Anonymous', age = 0 } = {}) {   console.log(`Hello, ${name}. You are ${age} years old.`); }  greet(); // 输出: Hello, Anonymous. You are 0 years old. 

五、解构赋值中的交换变量

        解构赋值可以简洁地交换两个变量的值,而不需要使用临时变量。

let a = 1; let b = 2;  [a, b] = [b, a];  console.log(a); // 输出: 2 console.log(b); // 输出: 1 

六、解构赋值与遍历

        解构赋值可以与 for-of 循环结合使用,来遍历对象或数组。

1、解构数组中的对象

const users = [   { name: 'Alice', age: 25 },   { name: 'Bob', age: 30 } ];  for (const { name, age } of users) {   console.log(`${name} is ${age} years old.`); }  // 输出: // Alice is 25 years old. // Bob is 30 years old. 

七、结合 rest 运算符

        解构赋值可以与 rest 运算符结合使用,用于提取剩余的属性。

const obj = { a: 1, b: 2, c: 3 };  const { a, ...rest } = obj;  console.log(a);    // 输出: 1 console.log(rest); // 输出: { b: 2, c: 3 } 

八、处理函数返回的对象或数组

        解构赋值可以用于处理函数返回的复杂对象或数组,使得函数调用更加简洁。

function getUserInfo() {   return {     name: 'Alice',     age: 25,     location: {       city: 'New York',       state: 'NY'     }   }; }  const {   name,   location: { city } } = getUserInfo();  console.log(name); // 输出: Alice console.log(city); // 输出: New York 

九、实际应用中的注意事项

1、属性不存在时的情况

        如果解构的对象中不存在某个属性,变量的值将是 undefined,因此使用默认值是一个好习惯。

const obj = { name: 'Alice' };  const { name, age } = obj;  console.log(age); // 输出: undefined 

2、深度解构可能导致错误

        深度嵌套的解构可能会导致 undefined 错误,因此在实际应用中要谨慎。

const obj = { name: 'Alice' };  // 错误:Cannot destructure property 'age' of 'undefined' as it is undefined. const { name, age: { year } } = obj; 

        在复杂数据结构中,务必确保数据的完整性,或为对象提供默认值。

十、总结

        解构赋值是一个强大且灵活的工具,它使得从数组和对象中提取数据变得更加简单和直观。通过掌握解构赋值的基本语法和实践,你可以写出更加简洁、可读性更强的代码。在实际项目中,解构赋值广泛应用于函数参数处理、变量交换、嵌套结构操作等场景,极大地提升了代码的灵活性和简洁度。

        只有锻炼思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~

        更多优质内容,请关注:

        你真的会使用Vue3的onMounted钩子函数吗?Vue3中onMounted的用法详解

        通过array.filter()实现数组的数据筛选、数据清洗和链式调用

        el-table实现动态数据的实时排序,一篇文章讲清楚elementui的表格排序功能

        极致的灵活度满足工程美学:用Vue Flow绘制一个完美流程图

        shpfile转GeoJSON且控制转化精度;如何获取GeoJSON?GeoJson结构详解

        Docker 入门全攻略:安装、操作与常用命令指南

        通过array.reduce()实现数据汇总、条件筛选和映射、对象属性的扁平化、转换数据格式等

        巧用Array.forEach:简化循环与增强代码可读性

        Mapbox添加行政区矢量图层、分级设色图层、自定义鼠标悬浮框、添加天地图底图等

        管理数据必备!侦听器watch用法详解

相关内容

热门资讯

安卓系统刷机神器,轻松实现系统... 你有没有想过,你的安卓手机是不是已经有点儿“老态龙钟”了呢?运行速度慢、系统卡顿,是不是让你有点抓狂...
安卓系统怎么设置黑名 你有没有遇到过那种让人头疼的骚扰电话?是不是觉得手机里的通讯录都快被这些讨厌的家伙填满了?别急,今天...
安卓12原生系统使用,功能革新... 你有没有发现,最近你的安卓手机是不是变得特别流畅,操作起来也更有趣了呢?没错,这就是安卓12原生系统...
安卓系统慢放视频,安卓系统视频... 你有没有遇到过这种情况?手机里存了好多好看的视频,想重温结果发现安卓系统播放视频时总是慢吞吞的,让人...
安卓系统钉钉相机,安卓系统下的... 你知道吗?在安卓系统的世界里,有一个超级好用的应用,那就是钉钉。而在这款强大的办公软件中,有一个隐藏...
安卓系统智能词典笔,随身携带的... 你有没有想过,在学习英语的过程中,有没有一种神器能让你随时随地提升词汇量,还能帮你纠正发音呢?今天,...
wp系统运行安卓软件,无缝体验... 你有没有想过,你的WP系统竟然也能运行安卓软件?没错,就是那个我们平时手机上用的安卓系统!这可不是天...
安卓系统的代理ip,解锁网络新... 你有没有想过,你的安卓手机里那些看似普通的设置,其实隐藏着大大的秘密呢?比如,那个神秘的“代理IP”...
目前手机安卓系统版本,探索手机... 你有没有发现,每次拿出手机,总感觉它好像在偷偷地升级呢?没错,说的就是那神秘的安卓系统版本。今天,就...
安卓系统哪里能录音,揭秘录音功... 你有没有想过,有时候在安卓手机上找到一个能录音的地方,就像在茫茫大海中寻找那颗最亮的星星一样困难呢?...
鹰眼监控安卓系统下载,揭秘安卓... 你有没有想过,你的手机里那些神秘的下载,其实都在鹰眼监控之下?没错,就是那个默默守护你手机安全的安卓...
光遇安卓系统串,探寻神秘代码背... 你有没有发现,最近光遇安卓系统的串号成了玩家们热议的话题呢?这不,我就来给你好好扒一扒这个神秘的串号...
怎么手机安装安卓系统,手机安装... 你有没有想过,为什么你的手机总是卡得跟蜗牛一样?是不是觉得安卓系统太复杂,想换个轻快的操作系统?别急...
安卓系统的色情游戏,暗流涌动的... 你有没有发现,最近你的安卓手机里突然多了不少色情游戏?没错,就是那种让你心跳加速、脸红心跳的游戏。今...
安卓卸载更新系统,轻松恢复纯净... 你有没有发现,手机里的安卓系统更新总是那么频繁?有时候,更新后的系统不仅没有带来预期的便利,反而让手...
安卓手机usb系统在哪,安卓手... 你有没有遇到过这种情况:手机里存了那么多宝贝照片、视频和文件,突然想备份却发现不知道安卓手机的USB...
安卓系统关闭推荐应用,安卓系统... 手机里的应用越来越多,是不是感觉像个小型的购物车,装满了各种推荐?别急,今天就来教你怎么关闭安卓系统...
ls系统定位比安卓系统定位,L... 你有没有想过,为什么有时候你的手机定位那么准,有时候又差得离谱呢?这背后其实有个大秘密,那就是LS系...
安卓系统鱼动态壁纸,鱼儿畅游的... 你有没有发现,手机里的壁纸已经不再只是单调的静态图片了?现在,安卓系统上的动态壁纸可是火得一塌糊涂呢...
圆通快递系统安卓版,轻松掌握快... 你有没有发现,现在的生活越来越离不开快递了?每天早上醒来,第一件事就是看看手机,期待着那个熟悉的快递...