」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 沒有「生命週期掛鉤」的生活

沒有「生命週期掛鉤」的生活

發佈於2024-11-08
瀏覽:425

Living without \

幾乎每個 JavaScript UI 庫 &/|我見過的框架有某種生命週期掛鉤:onmount、willmount、beforemount、aftermount、onunmount、onwhatever。

你真的需要它們嗎?它們是好是壞?沒有了還能活嗎?

那麼,首先為什麼會有這些?

  const oninit = (e: Element) => {
    e.style.prop = value;
    e.addEventListener('mouseover', handler);
    e.setAttribute('data-key', value);
  }

這是許多網路元件附帶和使用的典型(無聊)初始化樣板。 HTML 和CSS 的聲明性質旨在使這些變得多餘,但有時很難甚至不可能用預期值預設某些功能(想想禁用=“$ {()=> false}”,這不僅僅是表現得像人們所期望的)。

那我們做什麼呢?必須在初始化處理程序中設定我們剩下的所有內容。它有效,世界可以前進。

不過,這種方法有一個重要問題。如果出現問題,很難保證事件偵聽器和其他內容得到正確清理。給定的框架當然可以公開任何 onunmount 掛鉤,但如果應用程式邏輯中存在錯誤,那麼就會出現錯誤,或者最糟糕的是記憶體洩漏。


命令式程式設計是一種不幸的程式設計範例,它完全暴露在這些情況下。你幾乎可以做任何事情,包括破壞東西。

該解決方案附帶了控制反轉和函數式編程,這恰好不是 HTML 和 JavaScript 的構思方式,但有個好消息:我們仍然可以實現 FP 的一些基本設計模式並提供問題的戰略解決方案。

rimmel.js 是HTML 的概念性超集的參考實現,稱為Reactive Markup,其工作方式有點像JavaScript 的TypeScript,但它的目標是使HTML 和DOM 功能/功能反應。

這是透過將所有內容視為流來實現的:風格?這是一條溪流。 DOM 事件?當然,它們是流。 HTML 屬性?流也是如此。每當它們發出一個值時,它就被設定了。

讓我們看看它是如何運作的。

  const style = CreateStream({color: 'red'});
  const key = CreateStream('red', value);
  const handler = CreateStream();

  const template = rml`
    
`;

CreateStream 只是一個假設的流創建實用程式。通常,您更願意使用 Promises、Observables RxJS 流,因為它們最好地模擬 UI 互動。

如果您再次檢查程式碼,您很快就會意識到沒有 onmount 呼叫。事實上,沒有必要這樣做,因為 onmount 回呼之前執行的每個操作現在都會在這些流發出後立即完成。

任何給定的框架或 UI 庫都將負責卸載模板中定義或綁定的每個流:樣式、資料鍵、onmouseover。不存在忘記清理的風險,並且記憶體洩漏的可能性大大降低。

如果您是函數式程式設計的新手,您可能會花一些時間來了解如何用流來重新表述您的問題,但是當您成功時,將會有更多的好處等著您,例如大大減少程式碼大小(程式碼減少50% 到90%),更具可測試性且不易出錯的邏輯和實作。

準備好享受異國情調的體驗了嗎?查看 rimmel.js

版本聲明 本文轉載於:https://dev.to/dariomannu/living-without-lifecycle-hooks-4oce?1如有侵犯,請聯絡[email protected]刪除
最新教學 更多>
  • 如何增加 PHP 最大 POST 變數限制?
    如何增加 PHP 最大 POST 變數限制?
    PHP最大POST變數限制處理具有大量輸入欄位的POST請求時,當變數數量超過預設值時,會出現常見問題PHP 中的限制。例如,超過 1000 個欄位的表單可能只會公開 $_POST 陣列中的前 1001 個變數。 要解決此問題,需要調整 PHP 允許的 POST 變數的最大數量。在版本 5.3.9 ...
    程式設計 發佈於2024-11-09
  • 為什麼 OpenX 儀表板顯示「錯誤 330 (net::ERR_CONTENT_DECODING_FAILED)」?
    為什麼 OpenX 儀表板顯示「錯誤 330 (net::ERR_CONTENT_DECODING_FAILED)」?
    錯誤330 (net::ERR_CONTENT_DECODING_FAILED):解開壓縮問題遇到神祕的「錯誤330 (net::ERR_CONTENT_DER_CONTENT_DEDING_&&&B) ” “導航到儀表板時頁面,有必要深入研究根本原因。伺服器錯誤識別HTTP 請求中使用的內容壓縮方...
    程式設計 發佈於2024-11-09
  • 大批
    大批
    方法是可以在物件上呼叫的 fns 數組是對象,因此它們在 JS 中也有方法。 slice(begin):將陣列的一部分提取到新數組中,而不改變原始數組。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index ...
    程式設計 發佈於2024-11-09
  • 如何在Java中使用堆疊將算術表達式解析為樹結構?
    如何在Java中使用堆疊將算術表達式解析為樹結構?
    在Java 中將算術表達式解析為樹結構從算術表達式創建自定義樹可能是一項具有挑戰性的任務,特別是在確保樹結構時準確反映表達式的操作和優先順序。 要實現這一點,一種有效的方法是使用堆疊。以下是該過程的逐步描述:初始化:從空堆疊開始。 處理代幣:迭代表達式中的每個標記:如果標記是左括號,則壓入它 如果t...
    程式設計 發佈於2024-11-09
  • 在 Go 中使用 WebSocket 進行即時通信
    在 Go 中使用 WebSocket 進行即時通信
    构建需要实时更新的应用程序(例如聊天应用程序、实时通知或协作工具)需要一种比传统 HTTP 更快、更具交互性的通信方法。这就是 WebSockets 发挥作用的地方!今天,我们将探讨如何在 Go 中使用 WebSocket,以便您可以向应用程序添加实时功能。 在这篇文章中,我们将介绍: WebSoc...
    程式設計 發佈於2024-11-09
  • 如何進行有替換和無替換的有效加權隨機選擇?
    如何進行有替換和無替換的有效加權隨機選擇?
    帶有替換和不帶替換的加權隨機選擇為了應對編程挑戰,我們尋求從列表中進行加權隨機選擇的有效演算法,帶替換的加權選擇帶替換的加權選擇的一種有效方法是別名方法。此技術為每個加權元素建立一組相同大小的箱子。透過利用位元操作,我們可以有效地索引這些容器,而無需訴諸二分搜尋。每個 bin 儲存一個百分比,表示原...
    程式設計 發佈於2024-11-09
  • 如何在不依賴框架的情況下確定 DOM 準備?
    如何在不依賴框架的情況下確定 DOM 準備?
    Document.isReady:DOM 就緒偵測的本機解決方案依賴Prototype 和jQuery 等框架來管理window.onload 事件可能不會總是令人嚮往。本文探討了確定DOM 就緒情況的替代方法,特別是透過使用document.isReady.查詢Document.isReady對於...
    程式設計 發佈於2024-11-09
  • 如何在 Golang 中檢索 XML 陣列中的所有元素而不僅限於第一個元素?
    如何在 Golang 中檢索 XML 陣列中的所有元素而不僅限於第一個元素?
    在XML 中解組數組元素:檢索所有元素,而不僅僅是第一個當使用xml.Unmarshal( 在Golang 中解組XML 陣列時[]byte(p.Val.Inner), &t),您可能會遇到僅檢索第一個元素的情況。若要解決此問題,請利用 xml.Decoder 並重複呼叫其 Decode 方法。 解...
    程式設計 發佈於2024-11-09
  • 帶有管理面板的輕量級 Rest Api,可輕鬆管理食物食譜。
    帶有管理面板的輕量級 Rest Api,可輕鬆管理食物食譜。
    你好, ?所有這篇文章都是關於我剛剛在 Github 上發布的 Django Rest Framework API。 如果您正在尋找一些簡單且高效的 API 來從管理面板管理食物食譜並將其返回以供客戶端使用,那麼此儲存庫適合您。 該程式碼是輕量級的,可以在任何低功耗迷你 PC(如 Raspbe...
    程式設計 發佈於2024-11-09
  • 如何使用正規表示式來匹配帶有或不帶有可選 HTTP 和 WWW 前綴的 URL?
    如何使用正規表示式來匹配帶有或不帶有可選 HTTP 和 WWW 前綴的 URL?
    使用可選 HTTP 和 WWW 前綴匹配 URL正則表達式是執行複雜模式匹配任務的強大工具。當涉及到符合 URL 時,格式通常會有所不同,例如是否包含「http://www」。 使用正規表示式的解決方案匹配帶或不帶「http://www」的 URL。前綴,可以使用以下正規表示式:((https?|f...
    程式設計 發佈於2024-11-09
  • 如何在不依賴副檔名的情況下確定檔案類型?
    如何在不依賴副檔名的情況下確定檔案類型?
    如何在不依賴副檔名的情況下偵測檔案類型除了檢查檔案的副檔名之外,確定檔案是mp3 還是圖像格式是很有價值的程式設計中的任務。這是一個不依賴擴充的全面解決方案:PHP >= 5.3:$mimetype = finfo_fopen(fopen($filename, 'r'), FILEINFO_MIME...
    程式設計 發佈於2024-11-09
  • 在 JavaScript 中實作斐波那契數列:常見方法和變體
    在 JavaScript 中實作斐波那契數列:常見方法和變體
    作為開發人員,您可能遇到過編寫函數來計算斐波那契數列中的值的任務。這個經典問題經常出現在程式設計面試中,通常要求遞歸實現。然而,面試官有時可能會要求具體的方法。在本文中,我們將探討 JavaScript 中最常見的斐波那契數列實作。 什麼是斐波那契數列? 首先,讓我們回顧一下。斐波...
    程式設計 發佈於2024-11-09
  • 如何使用 .htaccess 更改共享伺服器上的 PHP 版本?
    如何使用 .htaccess 更改共享伺服器上的 PHP 版本?
    在共享伺服器上透過.htaccess 更改PHP 版本如果您正在操作共享伺服器並且需要更改PHP 版本,可以透過.htaccess文件來做到這一點。這允許您為您的網站運行特定的 PHP 版本,同時伺服器維護其預設版本。 要切換 PHP 版本,請按照下列步驟操作:找到 . htaccess 檔案: 該...
    程式設計 發佈於2024-11-09
  • 如何在Ajax資料載入過程中顯示進度條?
    如何在Ajax資料載入過程中顯示進度條?
    如何在Ajax 資料載入期間顯示進度條處理使用者觸發的事件(例如從下拉方塊中選擇值)時,通常會使用非同步擷取資料阿賈克斯。在獲取數據時,向用戶提供正在發生某事的視覺指示是有益的。本文探討了一種在 Ajax 請求期間顯示進度條的方法。 使用 Ajax 實作進度條要建立一個準確追蹤 Ajax 呼叫進度的...
    程式設計 發佈於2024-11-09
  • TCJavaScript 更新、TypeScript Beta、Node.js 等等
    TCJavaScript 更新、TypeScript Beta、Node.js 等等
    歡迎來到新一期的「JavaScript 本週」! 今天,我們從 TC39、Deno 2 正式版本、TypeScript 5.7 Beta 等方面獲得了一些針對 JavaScript 語言的巨大新更新,所以讓我們開始吧! TC39 更新:JavaScript 有何變化? 最近在東京...
    程式設計 發佈於2024-11-09

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

Copyright© 2022 湘ICP备2022001581号-3