」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > **擴充語法與其餘參數:ES2015 中的差異是什麼?

**擴充語法與其餘參數:ES2015 中的差異是什麼?

發佈於2024-11-17
瀏覽:629

**Spread Syntax vs Rest Parameter: What\'s the Difference in ES2015?**

擴展語法與剩餘參數:揭開ES2015 中的差異

瀏覽ES2015 中擴展語法和剩餘參數的細微差別可能是一個想法-令人難以置信的努力。在本指南中,我們將剖析它們在 JavaScript 不斷發展的格局中的對比角色。

理解擴展語法:從一到多

擴展語法(以' 表示) ...')允許我們將可迭代對象(例如數組)擴展到其各個元素。它對單一變數進行操作,將其分成更小的部分:

var abc = ['a', 'b', 'c'];
var def = ['d', 'e', 'f'];
var alpha = [ ...abc, ...def ];
console.log(alpha); // alpha will output ['a', 'b', 'c', 'd', 'e', 'f']

透過在'abc' 之前使用'...' 的擴展語法和'def',我們有效地將這些數組扁平化為單一合併數組。

揭開其餘參數:從多到一

相比之下,剩餘參數(前面也帶有“...”)從函數的參數列表中捕獲多個元素並將它們組合成一個陣列。當我們想要處理未知數量的參數時,通常會使用這種技術:

function sum(...args) {
  var sum = 0;
  for (var i = 0; i 

這裡,'...args' 充當傳遞給'sum' 函數的所有參數的佔位符,然後將其儲存在'args' 數組中。

主要區別:擴展與休息

雖然擴展語法和休息參數都使用“...”運算符,但它們具有不同的目的:

  • 擴展語法將迭代擴展為其各個元素。
  • 其餘參數將多個參數折疊為單一數組。

本質上,擴展語法可以幫助您分解變數分成其各個部分,而其餘參數將多個變數合併為一個有凝聚力的單元。

最新教學 更多>
  • 什麼時候手動呼叫析構函數是合法的做法?
    什麼時候手動呼叫析構函數是合法的做法?
    何時手動呼叫析構函數是合理的? 手動調用析構函數表明存在缺陷的設計這一概念經常被斷言。然而,這引出了一個問題:這條規則有例外嗎? 反例:需要手動析構函數呼叫的情況確實,在某些情況下有必要這樣做明確調用析構函數:1.受控記憶體釋放:當記憶體分配和釋放獨立於物件建構和銷毀進行管理時,手動析構函式呼叫變得...
    程式設計 發佈於2024-11-17
  • 大批
    大批
    方法是可以在物件上呼叫的 fns 數組是對象,因此它們在 JS 中也有方法。 slice(begin):將陣列的一部分提取到新數組中,而不改變原始數組。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index ...
    程式設計 發佈於2024-11-17
  • 為什麼我在 Django 資料庫查詢中收到「InterfaceError (0, \'\')\」?
    為什麼我在 Django 資料庫查詢中收到「InterfaceError (0, \'\')\」?
    在Django 查詢執行中遇到InterfaceError (0, '')Django 使用者可能會遇到持久的「InterfaceError (0 , '')” " 嘗試資料庫操作時出錯,特別是在伺服器重新啟動後。遊標,顧名思義,是與資料庫的持久連接,在多個...
    程式設計 發佈於2024-11-17
  • 如何在 PHP 中組合兩個關聯數組,同時保留唯一 ID 並處理重複名稱?
    如何在 PHP 中組合兩個關聯數組,同時保留唯一 ID 並處理重複名稱?
    在 PHP 中組合關聯數組在 PHP 中,將兩個關聯數組組合成一個數組是常見任務。考慮以下請求:問題描述:提供的代碼定義了兩個關聯數組,$array1 和 $array2。目標是建立一個新陣列 $array3,它合併兩個陣列中的所有鍵值對。 此外,提供的陣列具有唯一的 ID,而名稱可能重疊。要求是建...
    程式設計 發佈於2024-11-17
  • 使用 Go Module 部署 Go Cloud Functions 時如何解決「Build failed: go: parsing /models/go.mod: open /models/go.mod: no such file or directory\」錯誤?
    使用 Go Module 部署 Go Cloud Functions 時如何解決「Build failed: go: parsing /models/go.mod: open /models/go.mod: no such file or directory\」錯誤?
    使用Go 模組部署Google Cloud Function 錯誤嘗試使用Go 模組在Go 1.11 中部署Google Cloud Function 時,開發者可能會遇到錯誤,「建置失敗:go:解析/models/go.mod:開啟/models/go.mod:沒有這樣的檔案或目錄。」Go模組結構...
    程式設計 發佈於2024-11-17
  • 為什麼我的 Golang `exec.Command` 回傳「退出狀態 1」?
    為什麼我的 Golang `exec.Command` 回傳「退出狀態 1」?
    如何找出Golang的exec.Command中出現「Exit Status 1」錯誤的原因在Golang中執行exec.Command方法時,收到「退出狀態1」錯誤可能會非常模糊。缺乏特定資訊會阻礙有效的調試。 要檢索更詳細的信息,請利用 Command 物件的 Stderr 屬性。這是透過以下方...
    程式設計 發佈於2024-11-17
  • 如何使用「setState」更新狀態中的巢狀物件?
    如何使用「setState」更新狀態中的巢狀物件?
    使用setState 更新state.item[1] 在這種情況下,您正在嘗試更新物件內的物件使用setState 在在您的狀態中。若要正確更新狀態,您需要複製整個狀態對象,修改副本,然後將狀態設定為更新後的副本。 以下是如何更新 state.item[1] 使用setState:// 1. Mak...
    程式設計 發佈於2024-11-17
  • Bootstrap 4 Beta 中的列偏移發生了什麼事?
    Bootstrap 4 Beta 中的列偏移發生了什麼事?
    Bootstrap 4 Beta:列偏移的刪除和恢復Bootstrap 4 在其Beta 1 版本中引入了重大更改柱子偏移了。然而,隨著 Beta 2 的後續發布,這些變化已經逆轉。 從 offset-md-* 到 ml-auto在 Bootstrap 4 Beta 1 中, offset-md-*...
    程式設計 發佈於2024-11-17
  • 將 PHP 連接到資料庫:MySQL 初學者
    將 PHP 連接到資料庫:MySQL 初學者
    在PHP 中連接到MySQL 資料庫至關重要,步驟如下:安裝MySQL 擴充功能使用mysqli_connect() 函數建立連接,參數包括主機、使用者名稱、密碼和資料庫名稱使用mysqli_connect_error() 函數檢查連接是否成功實戰案例:取得所有用戶,透過查詢資料庫並使用mysqli...
    程式設計 發佈於2024-11-17
  • 為什麼 CSS `visibility:hidden` 無法達到懸停效果?
    為什麼 CSS `visibility:hidden` 無法達到懸停效果?
    揭開謎團:為什麼CSS 可見性在懸停時失敗CSS 可見性提供了操作元素可見性的便捷方法,但有時它會偶然發現意想不到的障礙。考慮這樣一個場景,您定義了一個「擾流器」類別來使文字最初不可見,並在滑鼠懸停時顯示它。儘管您有期望,文字仍然頑固地保持在隱藏狀態,無視您的懸停努力。 深入探討原因這種令人困惑的行...
    程式設計 發佈於2024-11-17
  • 何時在 JavaScript 中使用 parseInt() 和 Number() 進行字串到數字的轉換?
    何時在 JavaScript 中使用 parseInt() 和 Number() 進行字串到數字的轉換?
    使用parseInt()和Number()將字串轉換為數字在JavaScript中將字串轉換為數字時,兩個常用的函數是parseInt () 和數字()。雖然它們都具有相同的數值轉換目的,但它們的方法和行為有所不同。 parseInt()parseInt() 執行更具體的任務,稱為解析。它嘗試從字串...
    程式設計 發佈於2024-11-17
  • 項目 避免不必要地使用檢查異常
    項目 避免不必要地使用檢查異常
    檢查異常是 Java 中的一個強大工具,因為它們迫使程式設計師處理異常情況,從而提高程式碼可靠性。然而,過度使用可能會導致 API 難以使用。為了證明檢查異常是合理的,情況必須是真正的異常並且程式設計師能夠採取有用的操作。否則,未經檢查的異常可能更合適。 Java 8 為檢查異常的使用帶來了額外的...
    程式設計 發佈於2024-11-17
  • 為什麼我的 PDO 更新查詢無法修改 MySQL 中的特定行?
    為什麼我的 PDO 更新查詢無法修改 MySQL 中的特定行?
    使用PDO 進行MySQL 更新查詢當嘗試使用PDO 和MySQL 更新資料庫行時,您可能會遇到這樣的情況:您的程式碼執行失敗。本指南探討了此錯誤的可能原因並提供了解決方案。 錯誤:不正確的 UPDATE 語法您遇到的錯誤源自於不正確的 UPDATE 語法。具體來說,您的查詢正在嘗試用提供的值替換 ...
    程式設計 發佈於2024-11-17
  • 資料庫遷移對於 Golang 服務,為什麼重要?
    資料庫遷移對於 Golang 服務,為什麼重要?
    DB Migration, why it matters? Have you ever faced the situations when you deploy new update on production with updated database schemas, but ...
    程式設計 發佈於2024-11-17
  • 在 Go 中使用 WebSocket 進行即時通信
    在 Go 中使用 WebSocket 進行即時通信
    构建需要实时更新的应用程序(例如聊天应用程序、实时通知或协作工具)需要一种比传统 HTTP 更快、更具交互性的通信方法。这就是 WebSockets 发挥作用的地方!今天,我们将探讨如何在 Go 中使用 WebSocket,以便您可以向应用程序添加实时功能。 在这篇文章中,我们将介绍: WebSoc...
    程式設計 發佈於2024-11-17

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3