」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 我如何使用 dpdm 修復 Redux 中的循環依賴錯誤

我如何使用 dpdm 修復 Redux 中的循環依賴錯誤

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

How I Fixed a Circular Dependency Bug in Redux Using dpdm

打破混亂循環:Redux 循環依賴之旅

最近,我在 Redux 程式碼庫中偶然發現了一個讓我摸不著頭緒的錯誤。如果您曾經在測試套件拋出毫無意義的錯誤時感到突然的混亂,您就會知道這種感覺。這是發生的事情以及我最終如何發現(並解決)問題的。

循環依賴到底是什麼?

當兩個或多個模組直接或間接相互依賴時,就會發生循環依賴,從而在依賴鏈中創建無限循環。換句話說,就像兩個朋友說:“你先走”,但沒有人行動。在 JavaScript 中,這可能會導致未定義的模組或不完整的數據,從而導致難以追蹤的錯誤。

罪魁禍首:一個例子

想像兩個 JavaScript 文件,moduleA.js 和 moduleB.js:

// moduleA.js
import { functionB } from './moduleB.js';
export function functionA() {
  console.log('functionA called');
  functionB();
}

// moduleB.js
import { functionA } from './moduleA.js';
export function functionB() {
  console.log('functionB called');
  functionA();
}

在這裡,兩個模組相互依賴。當 JavaScript 嘗試載入它們時,它會感到困惑,因為如果對方沒有先準備好,則兩者都無法完全載入。這會導致諸如未定義的函數或不完整的模組之類的問題——基本上是一團糟。

那麼,我是如何找到我的循環依賴的呢?

啊,可怕的錯誤開始了這次冒險:

Error: `reducer` is a required argument, and must be a function or an object of functions that can be passed to combineReducers.
 ❯ Module.configureStore node_modules/@reduxjs/toolkit/src/configureStore.ts:98:11

我的第一個反應? 「等等,什麼?!」—這不是我最好的時刻。我確信我的減速器已就位,所以這個錯誤似乎是無中生有的。經過一番挖掘,我意識到這不是一個缺少減速器的問題,而是一個循環依賴潛入我的 Redux 設定中。當然,弄清楚這一點並不容易!

真正的英雄:dpdm

就在那時我找到了我的救星:npm 包 dpdm。這個 gem 分析您的依賴關係樹,並向您顯示那些偷偷摸摸的循環依賴關係所在的位置。運行以下命令給了我一個清晰的視圖:

dpdm --no-warning --no-tree ./src/index.tsx

瞧!以下是它在我的專案中發現的內容:

• Circular Dependencies
  01) src/stores/store.ts -> src/stores/rootReducer.ts -> src/stores/slice/authSlice.ts -> src/utilities/api.ts
  02) src/stores/rootReducer.ts -> src/stores/slice/bookingSlice.ts -> src/hooks/redux.tsx -> src/stores/types.ts -> src/stores/setUpStore.ts
  03) src/stores/types.ts -> src/stores/setUpStore.ts
  ...

解決方法:重構時間!

報告很清楚:我的 Redux 檔案中存在大量循環依賴項,主要在 store.ts、rootReducer.ts 和一些切片中。在拆分了一些邏輯、打破了不必要的依賴關係並重構了程式碼之後,我終於恢復正常了。

經驗教訓

  • 循環依賴是偷偷摸摸的:它們通常直到運行時或單元測試期間才會出現,這使得它們很難追蹤。
  • 像 dpdm 這樣的工具是救星:不要浪費時間手動搜尋導入。讓工具來完成繁重的工作。
  • 重構是你的朋友:有時循環依賴是糟糕架構的標誌。良好的重構不僅可以解決眼前的問題,還可以讓您的程式碼庫更乾淨且更易於維護。

所以,下次當你遇到這些討厭的錯誤時,喝杯咖啡,開懷大笑,打破這個循環!

調試愉快! ?

版本聲明 本文轉載於:https://dev.to/akshaysrepo/how-i-fixed-a-circular-dependency-bug-in-redux-using-dpdm-13ap?1如有侵犯,請聯絡[email protected]刪除
最新教學 更多>
  • 建立資訊機器人:初學者指南(HTML/CSS、JavaScript、Gemini API)
    建立資訊機器人:初學者指南(HTML/CSS、JavaScript、Gemini API)
    Table of Contents Introduction What is a Chatbot? Understanding the Problem Setting Up the Development Environment Understanding the Problem ...
    程式設計 發佈於2024-11-09
  • Python 中的實例方法與類別方法:什麼時候應該使用“self”和“cls”?
    Python 中的實例方法與類別方法:什麼時候應該使用“self”和“cls”?
    深入研究類別和實例方法的細微差別:Beyond Self 與ClsPython 增強提案(PEP) 8 建議使用“self”作為實例方法中的第一個參數,「cls」作為類別方法中的第一個參數。這種差異源自於這些方法在處理實例和類別時所扮演的不同角色。 實例方法:自我優勢實例方法在實例的實例上呼叫班級。...
    程式設計 發佈於2024-11-09
  • 在 Python 中使用 bytes(n) 時,與數位轉換的主要差異是什麼?
    在 Python 中使用 bytes(n) 時,與數位轉換的主要差異是什麼?
    Python 中的位元組物件:超越數位轉換在Python 中使用位元組物件時,必須了解bytes(n) 是如何轉換的函數與數值轉換不同。將整數 n 傳遞給 bytes(n) 不會傳回 n 的二進位表示形式,而是建立一個長度為 n 且填入有空位元組 (\x00) 的位元組字串。 行為背後的基本原則此行...
    程式設計 發佈於2024-11-09
  • 如何使用 Docker 部署 Go 應用程式
    如何使用 Docker 部署 Go 應用程式
    Docker is a containerization platform that simplifies applications’ packaging, distribution, and deployment. You can harness the benefits of Go and Do...
    程式設計 發佈於2024-11-09
  • 如何在 MySQL 中將紀元時間戳轉換為人類可讀的日期?
    如何在 MySQL 中將紀元時間戳轉換為人類可讀的日期?
    在 MySQL 中將紀元時間戳轉換為人類可讀的日期在 MySQL 中,紀元時間戳是日期和時間的數字表示形式。它是自 Unix 紀元(即 1970 年 1 月 1 日 00:00:00 UTC)以來的毫秒數。 要將紀元時間戳轉換為人類可讀的日期,您可以使用 from_unixtime( ) 功能。函數...
    程式設計 發佈於2024-11-09
  • 如何使用 Pip 取得可用軟體包版本清單:綜合指南
    如何使用 Pip 取得可用軟體包版本清單:綜合指南
    如何使用Pip 取得可用套件版本清單:綜合指南Pip 是一個廣泛使用的Python 套件安裝程序,提供了一個安裝和管理Python 套件的有效方法。雖然它允許方便地安裝特定的軟體包版本,但在選擇最佳版本之前可能有必要探索所有可能版本的綜合清單。本文深入探討如何在各種 pip 版本中實現此目的。 Pi...
    程式設計 發佈於2024-11-09
  • ## **`std::vector::erase`傳回的迭代器在刪除後是否指向有效元素? **
    ## **`std::vector::erase`傳回的迭代器在刪除後是否指向有效元素? **
    std::vector 迭代器失效:詳細解釋std::vector 中迭代器失效的概念經常被討論。需要澄清的是,透過 std::vector::erase 擦除向量元素會使嚴格位於已擦除元素之後的迭代器無效。 但是,位於已擦除元素的確切位置的迭代器的有效性仍然不確定。從邏輯上講,人們可能會假設該迭代...
    程式設計 發佈於2024-11-09
  • Python 開發人員如何增強調試技術以獲得更有效率的程式碼?
    Python 開發人員如何增強調試技術以獲得更有效率的程式碼?
    Python 中增強的調試技術增強 Python 中的調試過程對於尋求優化程式碼的開發人員至關重要。以下是一些幫助您完成此任務的寶貴提示:利用 PDB 模組PDB(Python 調試器)模組提供了全面的調試環境。透過將 pdb.set_trace() 整合到程式碼中,您可以在特定位置建立斷點。這個靈...
    程式設計 發佈於2024-11-09
  • AdaBoost - 整合方法,分類:監督機器學習
    AdaBoost - 整合方法,分類:監督機器學習
    Boosting Definition and Purpose Boosting is an ensemble learning technique used in machine learning to improve the accuracy of models...
    程式設計 發佈於2024-11-09
  • 重新學習CS基礎知識-實作佇列
    重新學習CS基礎知識-實作佇列
    你曾經站在隊列中嗎,隊列資料結構也做同樣的事情。當你想在你最喜歡的自助餐廳點餐時,你站在隊伍的最後,然後你就可以繼續排隊並離開。 CS 中的佇列資料結構執行相同的功能。佇列資料結構是先進先出的資料結構。佇列資料結構可以使用兩個基本函數 Enqueue 和 Dequeue 來構建,這兩個函數基本上是...
    程式設計 發佈於2024-11-09
  • 為 Angular 18 設定 linter 和 IDE
    為 Angular 18 設定 linter 和 IDE
    將 eslint、prettier、env 加入應用程式。 遺憾的是,Angular 預設不會自行產生這一切。更改原理圖可以提高數千個 Angular 專案的品質。 設定 eslint 9 連結 eslint: yarn ng add @angular-eslint/schema...
    程式設計 發佈於2024-11-09
  • 使用 JavaScript 進行網頁抓取和代理設定的初學者指南
    使用 JavaScript 進行網頁抓取和代理設定的初學者指南
    使用JavaScript程式碼模擬使用者操作,以取得所需資訊。包括模擬使用者開啟網頁、點擊連結、輸入關鍵字等操作,並從網頁中提取所需資訊。 Javascript網頁抓取的核心原理 使用JavaScript程式碼模擬使用者操作來取得所需資訊。包括模擬使用者開啟網頁、點擊連結、輸入關鍵...
    程式設計 發佈於2024-11-09
  • 在 Android 上運行 Llama:使用 Ollama 的逐步指南
    在 Android 上運行 Llama:使用 Ollama 的逐步指南
    Llama 3.2 最近在 Meta 開發者大會上推出,展示了令人印象深刻的多模式功能以及針對使用高通和聯發科技硬體的行動裝置進行最佳化的版本。這項突破使開發人員能夠在行動裝置上運行 Llama 3.2 等強大的 AI 模型,為更高效、私密和響應迅速的 AI 應用程式鋪平道路。 Meta 發布了 ...
    程式設計 發佈於2024-11-09
  • 如何在 Python 中格式化字串以將它們對齊直列?
    如何在 Python 中格式化字串以將它們對齊直列?
    以固定寬度列印字串列印字串時,將它們對齊成直列可以增強可讀性。在 Python 中使用 format 或 f-string 提供了實現此目的的便捷方法。 使用 str.format()str.format() 提供了一個簡單的填充方法字串。其語法包括佔位符 {},後跟格式化表達式。對於左對齊,請使用...
    程式設計 發佈於2024-11-09
  • 為什麼微服務比單體架構重要
    為什麼微服務比單體架構重要
    在當今快節奏的技術環境中,企業需要可擴展且靈活的解決方案來快速適應不斷變化的需求。與傳統的整體方法相比,這就是微服務架構的亮點。 1.什麼是單體架構? 單體架構是一個單一的、統一的系統,其中所有元件都是互連和相互依賴的。這意味著對系統的任何更改或更新都需要重新建置和重新部署整個應用...
    程式設計 發佈於2024-11-09

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

Copyright© 2022 湘ICP备2022001581号-3