搜尋
首頁web前端js教程聊聊JS解構的5個有趣使用方法

聊聊JS解構的5個有趣使用方法

Oct 24, 2022 pm 09:18 PM
javascript

這篇文章帶大家聊聊JavaScript解構(Destructuring)的5個有趣用法,希望給大家有幫助!

聊聊JS解構的5個有趣使用方法

1. 交換變數(Swap variables)

交換2個變數的常用做法是需要一個額外的暫存變數,來看一個簡單的場景:

let a = 1;
let b = 2;
let temp;

temp = a;
a = b;
b = temp;

a; // => 2
b; // => 1

temp是一個臨時變量,它保存a的值,然後將b的值賦給a,最後再把temp中儲存的a的值賦給b,完成了交換。
解構賦值讓變數交換更簡單,不需要明確建立臨時變數:

let a = 1;
let b = 2;

[a, b] = [b, a];

a; // => 2
b; // => 1

[a, b] = [b, a]是一個解構賦值。在右邊,建立了一個陣列[b, a],即[2,1],這個陣列的第一項(即值為2)被指派給a,第二項(即值為1)分配給b,完成了交換。
雖然這種方法仍然創建了一個臨時數組,但是這種交換變數的方式看起來更加簡潔。
不僅如此,這種方法還可以交換2個以上的變量,如下:

let zero = 2;
let one = 1;
let two = 0;

[zero, one, two] = [two, one, zero];

zero; // => 0
one;  // => 1
two;  // => 2

你可以交換任意多的變量!不過,交換兩個變數是最常見的場景。

2. 存取陣列項目(Access array item)

你有一個可能為空的陣列。你希望存取數組的第1個、第2個或第n個元素,但如果該元素不存在,則取得一個預設值。
通常你會使用陣列的長度屬性:

const colors = [];

let firstColor = 'white';
if (colors.length > 0) {
 firstColor = colors[0];
}

firstColor; // => 'white'

使用陣列解構實現相同的效果的程式碼量更少:

const colors = [];

const [firstColor = 'white'] = colors;

firstColor; // => 'white'

const [firstColor = 'white'] = colors解構將colors陣列的第一個元素賦給firstColor變數。如果陣列在索引0處沒有任何元素,則指派「white」預設值。
這裡提供了更大的靈活性,如果你只想訪問第二個元素,這也是可能的:

const colors = [];

const [, secondColor = 'black'] = colors;

secondColor; // => 'black'

注意解構左邊的逗號:它表示忽略第一個元素。 secondColorcolors陣列中索引1處的元素賦值。

3. 不變的操作(Immutable operations)

#當我開始使用React和後來的Redux時,我被迫編寫了一些涉及不可變性的程式碼(這裡的意思是保持原對像不變)。雖然一開始有點困難,但後來我看到了它的好處:更容易處理單向資料流
不變性是指禁止改變物件。幸運的是,解構可以幫助你輕鬆地以不可變的方式實現某些操作。
解構與rest運算子(...)結合來刪除陣列的第一個元素:

const numbers = [1, 2, 3];

const [, ...fooNumbers] = numbers;

fooNumbers; // => [2, 3]
numbers; // => [1, 2, 3]

[, ...fooNumbers] = numbers解構,創建了一個新的陣列fooNumbers,它包含了numbers陣列中除第一個元素以外的其他元素。 numbers陣列沒有發生變化,保持了運算不變性。
以同樣不可變的方式,你可以從物件中刪除屬性。讓我們試著從big物件中刪除foo屬性:

const big = {
 foo: 'value Foo',
 bar: 'value Bar'
};

const { foo, ...small } = big;

small; // => { bar: 'value Bar' }
big; // => { foo: 'value Foo', bar: 'value Bar' }

解構賦值與物件rest運算子結合,建立一個新物件small,它包含了big物件中除foo屬性外的所有屬性。

4. 解構可迭代物件(Destructuring iterables)

在前面的小節中,對陣列應用了解構。但是你可以對任何實作可迭代協定(iterable protocol)的物件進行解構。
許多原生基本類型和物件都是可迭代的:陣列(arrays)、字串(string)、類別陣列(typed arrays)、集合(set)和映射(map)。
例如,你可以把一個字串解構成幾個字元:

const str = 'cheese';

const [firstChar = ''] = str;

firstChar; // => 'c'

你並不用局限於原生的類型,透過實作可迭代協議,可以自訂解構邏輯。
movies包含一個movie物件的清單。在解構movies時,將電影標題作為字串來獲取是非常棒的。讓我們實作一個自訂迭代器:

const movies = {
  list: [
    { title: 'Heat' }, 
    { title: 'Interstellar' }
  ],
  [Symbol.iterator]() {
    let index = 0;
    return {
      next: () => {
        if (index < this.list.length) {
          const value = this.list[index++].title;
          return { value, done: false };
        }
        return { done: true };
      }
    };
  }
};

const [firstMovieTitle] = movies;
console.log(firstMovieTitle); // => &#39;Heat&#39;

movies物件透過定義Symbol.iterator來實作可迭代協定。迭代器的方法:迭代電影的標題。
遵循迭代協議允許將movies物件解構為標題,取得第一部電影標題的具體方法是:const [firstMovieTitle] = movies

5. 解構動態屬性(Destructuring dynamic properties)

根據我的經驗,透過屬性對物件進行解構比陣列解構更常見。物件的解構看起來很簡單:

const movie = { title: &#39;Heat&#39; };

const { title } = movie;

title; // => &#39;Heat&#39;

const {title} = movie建立一個變數title,並將屬性movie.title的值賦給它。
當我第一次讀到物件解構時,我有點驚訝於你不必靜態地知道屬性名,你可以使用動態屬性名稱來解構物件!

function greet(obj, nameProp) {
 const { [nameProp]: name = &#39;Unknown&#39; } = obj;
 return `Hello, ${name}!`;
}

greet({ name: &#39;Batman&#39; }, &#39;name&#39;); // => &#39;Hello, Batman!&#39;
greet({ }, &#39;name&#39;); // => &#39;Hello, Unknown!&#39;

greet()函数有两个参数:对象和属性名。在greet()函数内部,解构赋值const {[nameProp]: name = 'Unknown'} = obj使用中括号[nameProp]读取动态属性名,name变量作为别名接收动态属性值。如果属性不存在,你还可以给它赋一个默认值Unknown

6. 总结

如果你想访问对象属性和数组元素,那么解构非常有用。
在基本用法之上,数组解构便于交换变量、访问数组项、执行一些不可变的操作。
JavaScript提供了更大的可能性,因为你可以使用迭代器定义自定义的解构逻辑。

本文翻译自:5 Interesting Uses of JavaScript Destructuring

地址:https://dmitripavlutin.com/5-interesting-uses-javascript-destructuring/

【相关推荐:javascript视频教程编程视频

以上是聊聊JS解構的5個有趣使用方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文轉載於:csdn。如有侵權,請聯絡admin@php.cn刪除
超越瀏覽器:現實世界中的JavaScript超越瀏覽器:現實世界中的JavaScriptApr 12, 2025 am 12:06 AM

JavaScript在現實世界中的應用包括服務器端編程、移動應用開發和物聯網控制:1.通過Node.js實現服務器端編程,適用於高並發請求處理。 2.通過ReactNative進行移動應用開發,支持跨平台部署。 3.通過Johnny-Five庫用於物聯網設備控制,適用於硬件交互。

使用Next.js(後端集成)構建多租戶SaaS應用程序使用Next.js(後端集成)構建多租戶SaaS應用程序Apr 11, 2025 am 08:23 AM

我使用您的日常技術工具構建了功能性的多租戶SaaS應用程序(一個Edtech應用程序),您可以做同樣的事情。 首先,什麼是多租戶SaaS應用程序? 多租戶SaaS應用程序可讓您從唱歌中為多個客戶提供服務

如何使用Next.js(前端集成)構建多租戶SaaS應用程序如何使用Next.js(前端集成)構建多租戶SaaS應用程序Apr 11, 2025 am 08:22 AM

本文展示了與許可證確保的後端的前端集成,並使用Next.js構建功能性Edtech SaaS應用程序。 前端獲取用戶權限以控制UI的可見性並確保API要求遵守角色庫

JavaScript:探索網絡語言的多功能性JavaScript:探索網絡語言的多功能性Apr 11, 2025 am 12:01 AM

JavaScript是現代Web開發的核心語言,因其多樣性和靈活性而廣泛應用。 1)前端開發:通過DOM操作和現代框架(如React、Vue.js、Angular)構建動態網頁和單頁面應用。 2)服務器端開發:Node.js利用非阻塞I/O模型處理高並發和實時應用。 3)移動和桌面應用開發:通過ReactNative和Electron實現跨平台開發,提高開發效率。

JavaScript的演變:當前的趨勢和未來前景JavaScript的演變:當前的趨勢和未來前景Apr 10, 2025 am 09:33 AM

JavaScript的最新趨勢包括TypeScript的崛起、現代框架和庫的流行以及WebAssembly的應用。未來前景涵蓋更強大的類型系統、服務器端JavaScript的發展、人工智能和機器學習的擴展以及物聯網和邊緣計算的潛力。

神秘的JavaScript:它的作用以及為什麼重要神秘的JavaScript:它的作用以及為什麼重要Apr 09, 2025 am 12:07 AM

JavaScript是現代Web開發的基石,它的主要功能包括事件驅動編程、動態內容生成和異步編程。 1)事件驅動編程允許網頁根據用戶操作動態變化。 2)動態內容生成使得頁面內容可以根據條件調整。 3)異步編程確保用戶界面不被阻塞。 JavaScript廣泛應用於網頁交互、單頁面應用和服務器端開發,極大地提升了用戶體驗和跨平台開發的靈活性。

Python還是JavaScript更好?Python還是JavaScript更好?Apr 06, 2025 am 12:14 AM

Python更适合数据科学和机器学习,JavaScript更适合前端和全栈开发。1.Python以简洁语法和丰富库生态著称,适用于数据分析和Web开发。2.JavaScript是前端开发核心,Node.js支持服务器端编程,适用于全栈开发。

如何安裝JavaScript?如何安裝JavaScript?Apr 05, 2025 am 12:16 AM

JavaScript不需要安裝,因為它已內置於現代瀏覽器中。你只需文本編輯器和瀏覽器即可開始使用。 1)在瀏覽器環境中,通過標籤嵌入HTML文件中運行。 2)在Node.js環境中,下載並安裝Node.js後,通過命令行運行JavaScript文件。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
3 週前By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
4 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

mPDF

mPDF

mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能