Javascript 中的解构赋值语法

开发 前端
首先在 ES6中引入的“解构赋值语法”允许把数组和对象中的值插入到不同的变量中。虽然看上去可能很难,但实际上很容易学习和使用。

首先在 ES6中引入的“解构赋值语法”允许把数组和对象中的值插入到不同的变量中。虽然看上去可能很难,但实际上很容易学习和使用。

[[390966]]

数组解构

数组解构非常简单。你所要做的就是为数组中的每个值声明一个变量。你可以定义更少的变量,而不是数组中的索引(即,如果你只想解处理前几个值),请跳过某些索引或甚至使用 REST 模式将所有剩余的值放到新数组中。

  1. const nums = [ 3, 6, 9, 12, 15 ]; 
  2. const [ 
  3.   k,              // k = 3 
  4.   l,              // l = 6 
  5.   ,               // Skip a value (12) 
  6.   ...n            // n = [12, 15] 
  7. ] = nums; 

对象解构

对象解构与数组解构非常相似,主要区别是可以按名称引用对象中的每个key,从而创建一个有相同名称的变量。此外还可以将键解构为新的变量名,只解构所需的 key,然后用 rest 模式将剩余的 key 解构为新对象。

  1. const obj = { a: 1, b: 2, c: 3, d: 4 }; 
  2. const { 
  3.   a,              // a = 1 
  4.   c: d,           // d = 3 
  5.   ...rest         // rest = { b: 2, d: 4 } 
  6. } = obj; 

嵌套解构

嵌套对象和数组可以通过相同的规则来进行解构。区别在于可以将嵌套 key 或值直接解构为变量,而不必将父对象存储在变量本身中。

  1. const nested = { a: { b: 1, c: 2 }, d: [1, 2]}; 
  2. const { 
  3.   a: { 
  4.     b: f,         // f = 1 
  5.     ...g          // g = { c: 2 } 
  6.   }, 
  7.   ...h            // h = { d: [1, 2]} 
  8. } = nested; 

高级解构

由于数组的行为与对象相似,所以可以通过使用索引作为对象解构分配中的 key,用解构分配语法从数组中获取特定值。用这种方法还可以得到数组的其他属性(例如数组的 length)。最后,如果解构后的值是 undefined,则还可以为解构过程中的变量定义默认值。

  1. const arr = [ 5, 'b', 4, 'd', 'e', 'f', 2 ]; 
  2. const { 
  3.   6: x,           // x = 2 
  4.   0: y,           // y = 5 
  5.   2: z,           // z = 4 
  6.   length: count,  // count = 7 
  7.   name = 'array', // name = 'array' (not present in arr) 
  8.   ...restData     // restData = { '1': 'b', '3': 'd', '4': 'e', '5': 'f' } 
  9. } = arr; 

 

责任编辑:赵宁宁 来源: 前端先锋
相关推荐

2021-07-26 05:20:47

JavaScript解构赋值数组解构

2019-12-03 19:09:19

JavaScriptNumbers阿里云计算

2010-01-04 16:16:31

JavaScript语

2010-10-09 10:10:55

JavaScriptFunction对象

2021-07-27 06:49:11

C#存储检索

2020-07-14 13:16:32

JavaScript解构对象

2009-06-09 21:59:13

语法高亮Javascript

2012-05-22 01:20:14

SyntaxHighlJavaScriptJava

2015-10-26 10:01:33

解构C#小数运算

2023-05-17 09:31:38

华为分销华为伙伴体系

2012-11-08 10:40:47

JavaScript原型链

2010-09-17 10:24:47

SQL中IS NULL

2010-09-30 15:19:33

2017-07-24 09:45:15

JavaScript语法代码

2010-09-24 17:19:54

SQL中SUBSTRI

2022-02-14 08:04:02

Go语法糖编译器

2020-12-08 07:51:53

Java语法糖泛型

2017-07-26 17:38:10

JavaScriptBabel

2022-09-02 07:39:15

存算存储私有云

2014-01-03 09:13:39

JavaScriptthis
点赞
收藏

51CTO技术栈公众号