JavaScript - 嵌套解构



嵌套解构

JavaScript 中的嵌套解构允许我们从嵌套对象和数组中提取数据。对象(或数组)可以在其内部包含另一个对象(或数组),称为嵌套对象(或数组)。解包嵌套对象或数组称为嵌套解构。我们可以使用解构提取对象或数组中的全部或部分数据。

我们可以将从嵌套数组或对象中提取的数据分配给变量。这被称为嵌套解构赋值。当使用嵌套解构从嵌套数组或对象中获取某些值时,必须遵循数组或对象的结构。

嵌套对象解构

本节将演示 JavaScript 中的嵌套对象解构。

语法

JavaScript 中嵌套对象解构的语法如下:

const {prop1, prop2: {nestedprop1, nestedprop2}} = obj;

在上述语法中,prop1 是对象的属性,而prop2 属性包含嵌套对象,该对象具有nestedprop1nestedprop2 属性。

示例

在下面的示例中,car 对象包含 brand、model 和 info 属性。info 属性包含嵌套对象,其中包含 price 和 color 属性。

我们已经解构了嵌套对象,并在输出中打印了变量的值。

<html>
<body>
   <p id = "output"> </p>
   <script>
      const car = {
         brand: "Hyundai",
         model: "Verna",
         info: {
            price: 1200000, // Nested properties
            color: "white",
         }
      }
      const { brand, model, info: { price, color } } = car; // Destructuring
      document.getElementById("output").innerHTML = 
	   `Brand: ${brand} <br> Model: ${model} <br> Price: ${price} <br> Color: ${color}`;
   </script>
</body>
</html>

输出

Brand: Hyundai
Model: Verna
Price: 1200000
Color: white

示例:嵌套对象解构和变量重命名

下面的代码演示了在解包嵌套对象属性时可以重命名变量。

我们将 brand、model、price 和 color 变量重命名为 company、name、cost 和 carColor。

<html>
<body>
<p id = "output"> </p>
<script>

   const car = {
      brand: "Hyundai",
      model: "Verna",
      info: {
         price: 1200000, // Nested properties
         color: "white",
      }
   }
   // Destructuring
   const {brand: company, model: name, info: {price: cost, color: carColor }} = car;

   document.getElementById("output").innerHTML = 
   `Company: ${company}, Name: ${name}, Cost: ${cost}, Color: ${carColor}`;
</script>
</body>
</html>

输出

Company: Hyundai, Name: Verna, Cost: 1200000, Color: white

示例:嵌套对象解构和默认值

您可以使用赋值运算符为变量分配默认值。每当对象的特定属性未定义时,它都会使用默认值初始化变量。

在这里,我们重命名了每个变量并分配了默认值。“science”属性未在 grades(嵌套对象)对象中定义。因此,代码在输出中打印其默认值。

<html>
<body>
   <p id = "output"> </p>
   <script>
      const student = {
         firstName: "Sam",
         lastName: "Raina",
         grades: {
            English: 75,
         }
      };
    
      const { firstName: name = "Jay", 
         lastName: surname = "Shah", 
         grades: { English: eng = 0, Science: sci = 0 } 
      } = student;
      
      document.getElementById("output").innerHTML = 
      `Name: ${name} <br> Surname: ${surname} <br> English: ${eng} <br> Science: ${sci}`;
   </script>
</body>
</html>

输出

Name: Sam
Surname: Raina
English: 75
Science: 0

示例:嵌套对象解构和 rest 运算符

rest 运算符允许您将剩余的属性收集到单个对象中。

在下面的代码中,grades 对象包含 4 个不同的属性。我们使用 rest 运算符将 Maths 属性的值存储在 Maths 变量中,并将其他属性存储在 'allGrades' 变量中。“allGrades”是一个包含 3 个属性的对象。

<html>
<body>
   <p id = "output"> </p>
   <script>
      const student = {
         firstName: "Kunal",
         lastName: "Karma",
         grades: {
            English: 75,
            Maths: 87,
            SocialScience: 90,
            Science: 80,
         }
      };
      const { firstName, lastName, grades: { Maths, ...allGrades } } = student;
      document.getElementById("output").innerHTML = 
		`firstName: ${firstName} <br>
		 lastName: ${lastName} <br>
		 Maths: ${Maths} <br>
		 allGrades: ${JSON.stringify(allGrades)} <br>
		 `;
   </script>
</body>
</html>

输出

firstName: Kunal
lastName: Karma
Maths: 87
allGrades: {"English":75,"SocialScience":90,"Science":80}

嵌套数组解构

本节将演示 JavaScript 中的嵌套数组解构。

语法

在 JavaScript 中解包嵌套数组元素(嵌套数组解构)的语法如下:

const [a, [b, c], d] = arr;

在上述语法中,我们将嵌套数组元素存储在 b 和 c 变量中。

示例

在下面的代码中,arr 数组包含嵌套数组。我们将嵌套数组元素解包到 b 和 c 变量中。在输出中,您可以观察到 b 和 c 变量的值。

<html>
<body>
   <p id = "output"> </p>
   <script>
      const arr = [10, [15, 20], 30];
      const [a, [b, c], d] = arr;
      document.getElementById("output").innerHTML = 
      "a = " + a + ", b = " + b + ", c = " + c + ", d = " + d; 
   </script>
</body>
</html>

输出

a = 10, b = 15, c = 20, d = 30

示例:跳过嵌套数组的元素

赋值解构允许您跳过嵌套数组的元素。这里,arr 数组包含两个嵌套数组。我们在解构嵌套数组时跳过每个嵌套数组的第一个元素。

<html>
<body>
   <p id = "output"> </p>
   <script>
      const arr = [2, [3, 4], [9, 10]];
      const [a, [, b], [, c]] = arr;
      document.getElementById("output").innerHTML = 
      "a = " + a + ", b = " + b + ", c = " + c; 
   </script>
</body>
</html>

输出

a = 2, b = 4, c = 10

示例:嵌套数组解构和默认值

解构嵌套数组时,您可以像对象一样为变量分配默认值。

这里,arr [3, 4] 的第一个嵌套数组包含两个元素。解构时,我们跳过了前两个元素并使用变量 p 获取第三个元素,但嵌套数组仅包含两个元素。因此,变量 p 的值为 29(默认值)。

<html>
<body>
   <p id = "output"> </p>
   <script>
      const arr = [2, [3, 4], [9, 10]];
      const [, [, , p = 29], [, q]] = arr;
      document.getElementById("output").innerHTML =
      "p = " + p + ", q = " + q; 
   </script>
</body>
</html>

输出

p = 29, q = 10

示例:嵌套数组解构和 rest 运算符

您可以使用剩余运算符结合嵌套数组解构。这里,变量b存储第一个嵌套数组的剩余元素,变量c存储父数组的剩余元素,其中包括第二个嵌套数组和最后一个数组元素。

<html>
<body>
   <p id = "output"> </p>
   <script>
      const arr = [[6, 7, 8, 9], [10, 11, 12, 13], 14];
      const [[a, ...b], ...c] = arr
      document.getElementById("output").innerHTML = 
      "a = " + a + "<br> b = " + b + "<br> c = " + c; 
   </script>
</body>
</html>

输出

a = 6
b = 7,8,9
c = 10,11,12,13,14

对象中的数组 – 嵌套解构

有时,我们需要解构包含数组的对象。让我们通过下面的例子来理解它。

示例

在下面的例子中,numbers对象的num2属性包含数组。我们解构对象的属性并在输出中打印值。

<html>
<body>
   <p id = "output"> </p>
   <script>
      const numbers = {
         num1: 10,
         num2: [40, 6, 5],
      }
      const {num1, num2: [a, b, c]} = numbers;
      document.getElementById("output").innerHTML = 
      "num1 = " + num1 + ", a = " + a + ", b = " + b + ", c = " + c; 
   </script>
</body>
</html>

输出

num1 = 10, a = 40, b = 6, c = 5

数组中的对象 – 嵌套解构

在某些情况下,数组也可以包含对象,您需要从数组中解构对象。

示例

在下面的代码中,numbers数组包含包含p和q属性的对象。

之后,我们解构数组并解包对象的属性。

<html>
<body>
   <p id = "output"> </p>
   <script>
      const numbers = [10, { p: 20, q: 30 }]
      const [a, { p, q }] = numbers;
      document.getElementById("output").innerHTML = 
      "a = " + a + ", p = " + p + ", q = " + q; 
   </script>
</body>
</html>

输出

a = 10, p = 20, q = 30
广告