」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > React 中的 Prop Drilling:定義與範例

React 中的 Prop Drilling:定義與範例

發佈於2024-08-21
瀏覽:357

Prop Drilling in React: definition and examples

是否曾經發現自己處於需要將一些資料獲取到深埋在 React 應用程式中的元件中的情況?你已經在較高的層次上獲得了這條重要的訊息,但你的組件位於樹的下方,現在你必須透過一堆層傳遞道具才能到達那裡。這就是我們所說的「螺旋槳鑽井」。

您首先將訊息作為 prop 從父元件傳送到其直接子元件。然後,該子級將相同的訊息傳遞給自己的子級,依此類推,一層一層地傳遞,直到訊息最終到達真正需要它的元件。

因此,如果您正在處理在組件樹中移動的大量 props 並且感覺有點過頭了,那麼您可能正在處理 prop 鑽探。讓我們深入了解它是什麼以及為什麼值得尋找替代方法來處理數據。

什麼是支柱鑽井?

道具鑽探,有時稱為“線程道具”或“組件鏈接”,是使用道具從父組件通過一系列嵌套子組件傳遞資料的方法。

當您需要透過多個層級的元件發送道具以將其傳送到需要它的深層嵌套子元件時,就會發生這種情況。鏈中的每個中間組件都必須轉送該 prop,即使它不直接使用它。

課堂隱喻

想像一下,一位老師需要與一長排課桌上的最後一個學生分享一則重要訊息。老師沒有直接傳遞訊息,而是交給第一位學生。然後,該學生將其傳遞給下一個學生,依此類推,該行中的每個學生都將訊息轉發給下一個學生,直到訊息最終到達最後一個學生。在這種情況下,每個學生都充當中介,確保訊息從源頭傳輸到最終接收者。這個過程反映了編程中的道具鑽探,其中資料在到達實際需要的組件之前通過多層組件傳遞。

讓我們在程式碼範例中看看:

// Parent Component (Teacher)
function Teacher() {
  const messageToLastStudent = "Helo, Last Student!";
  return (
    
  );
}

// Child Component (First Student)
function FirstStudent({ message }) {
  // The message is passed directly as prop, without be used here.
  return (
    
  );
}

// Grandson Component (Last Student)
function LastStudent({ message }) {
  return 

{message}

; // Here the message is finally used. }

支柱鑽井的困難

當你的應用程式的元件樹小而簡單時,Prop Drill 非常方便。將資料從父級傳遞給幾個嵌套的子級很容易。但隨著你的應用程式的成長,你可能會遇到一些問題:

  • 複雜性代碼:道具鑽探會增加複雜性和額外的樣板,尤其是在大型組件樹中。隨著元件的嵌套程度越來越高,追蹤 prop 流變得更加困難,並且會使程式碼庫變得混亂。

  • 對效能的影響:將資料傳遞到多層元件可能會對效能產生負面影響,特別是在處理大量資料時。這是因為鏈中的每個元件在屬性變更時都需要再次重新渲染,這會導致不必要的重新渲染。

解決支柱鑽井問題

但一切並沒有失去!我們有有效的方法來避免支柱鑽井並保持應用性能:

  • Context API:React 中的 Context API 允許您直接跨組件共享數據,而無需在組件樹的每個級別傳遞 props,從而幫助避免 prop 鑽探。透過使用 React.createContext 和 Context.Provider,您可以讓資料可供提供者中的任何元件使用,從而無需將 props 傳遞到多個層。這簡化了資料管理並降低了元件層次結構的複雜性。

  • 狀態管理庫
    狀態管理庫透過為應用程式資料提供集中儲存來幫助避免道具鑽探。 Redux、MobX 和 Zustand 等函式庫管理全域狀態,允許元件存取和更新數據,而無需在每個層級傳遞 props。例如,Redux 使用全域儲存和連接或 useSelector 掛鉤將元件連接到狀態,使資料存取變得簡單並減少深層 prop 傳遞的需要。

  • 高階組件 (HOC):
    高階組件 (HOC) 透過使用附加功能和資料包裝組件來幫助避免鑽探。 HOC 取得一個元件並傳回一個有註入 props 或增強行為的新元件。這允許您向深度嵌套的組件提供資料或功能,而無需透過每一層傳遞 props。例如,HOC 可以包裝元件以向其提供使用者身份驗證數據,從而簡化資料存取並減少 prop 傳遞。

結論

簡而言之,道具鑽探可以是透過幾層元件傳遞資料的快速解決方案,但隨著應用程式的成長,它很快就會變成一團混亂。雖然它適用於較小的應用程序,但在較大的專案中可能會導致程式碼混亂和維護麻煩。幸運的是,有 Context API、狀態管理庫和高階元件等工具可以幫助您避開 prop 鑽探陷阱並保持程式碼庫乾淨且易於管理。因此,下次您處理道具時,請考慮這些替代方案,以保持事情順利進行!

讓我們共創未來! ?

版本聲明 本文轉載於:https://dev.to/ericlefyson/prop-drilling-in-react-definition-and-examples-1395?1如有侵犯,請聯絡[email protected]刪除
最新教學 更多>
  • TypeScript 冒險與類型挑戰 – Day Pick
    TypeScript 冒險與類型挑戰 – Day Pick
    大家好。 我正在解決類型挑戰,以更深入地研究 TypeScript。 今天,我想分享一下我對Pick的了解。 - 挑戰 - interface Todo { title: string description: string completed: boolean }...
    程式設計 發佈於2024-11-03
  • 如何擴展 JavaScript 中的內建錯誤物件?
    如何擴展 JavaScript 中的內建錯誤物件?
    擴充 JavaScript 中的 Error要擴充 JavaScript 中的內建 Error 對象,您可以使用 extends 關鍵字定義 Error 的子類別。這允許您使用附加屬性或方法建立自訂錯誤。 在 ES6 中,您可以定義自訂錯誤類,如下所示:class MyError extends E...
    程式設計 發佈於2024-11-03
  • 將測試集中在網域上。 PHPUnit 範例
    將測試集中在網域上。 PHPUnit 範例
    介紹 很多時候,開發人員嘗試測試 100%(或幾乎 100%)的程式碼。顯然,這是每個團隊應該為他們的專案達到的目標,但從我的角度來看,只應該完全測試整個程式碼的一部分:您的網域。 域基本上是程式碼中定義項目實際功能的部分。例如,當您將實體持久保存到資料庫時,您的網域不負責將其持...
    程式設計 發佈於2024-11-03
  • 如何使用 SQL 搜尋列中的多個值?
    如何使用 SQL 搜尋列中的多個值?
    使用 SQL 在列中搜尋多個值建立搜尋機制時,通常需要在同一列中搜尋多個值場地。例如,假設您有一個搜尋字串,例如“Sony TV with FullHD support”,並且想要使用該字串查詢資料庫,將其分解為單字。 透過利用 IN 或 LIKE 運算符,您可以實現此功能。 使用 IN 運算子IN...
    程式設計 發佈於2024-11-03
  • 如何安全地從 Windows 登錄讀取值:逐步指南
    如何安全地從 Windows 登錄讀取值:逐步指南
    如何安全地從Windows 註冊表讀取值檢測登錄項目是否存在確定登錄項目是否存在: LONG lRes = RegOpenKeyExW(HKEY_LOCAL_MACHINE, L"SOFTWARE\\Perl", 0, KEY_READ, &hKey); if (lRes...
    程式設計 發佈於2024-11-03
  • Staat原始碼中的useBoundStoreWithEqualityFn有解釋。
    Staat原始碼中的useBoundStoreWithEqualityFn有解釋。
    在這篇文章中,我們將了解Zustand原始碼中useBoundStoreWithEqualityFn函數是如何使用的。 上述程式碼摘自https://github.com/pmndrs/zustand/blob/main/src/traditional.ts#L80 useBoundStoreWi...
    程式設計 發佈於2024-11-03
  • 如何使用 Go 安全地連接 SQL 查詢中的字串?
    如何使用 Go 安全地連接 SQL 查詢中的字串?
    在Go 中的SQL 查詢中連接字串雖然文字SQL 查詢提供了一種簡單的資料庫查詢方法,但了解將字串文字與值連接的正確方法至關重要以避免語法錯誤和類型不匹配。 提供的查詢語法:query := `SELECT column_name FROM table_name WHERE colu...
    程式設計 發佈於2024-11-03
  • 如何在 Python 中以程式設計方式從 Windows 剪貼簿檢索文字?
    如何在 Python 中以程式設計方式從 Windows 剪貼簿檢索文字?
    以程式設計方式存取Windows 剪貼簿以在Python 中進行文字擷取Windows 剪貼簿充當資料的臨時存儲,從而實現跨應用程式的無縫數據共享。本文探討如何使用 Python 從 Windows 剪貼簿檢索文字資料。 使用 win32clipboard 模組要從 Python 存取剪貼簿,我們可...
    程式設計 發佈於2024-11-03
  • 使用 MySQL 預存程序時如何存取 PHP 中的 OUT 參數?
    使用 MySQL 預存程序時如何存取 PHP 中的 OUT 參數?
    使用MySQL 預存程序存取PHP 中的OUT 參數使用MySQL 儲存程序存取PHP 中的OUT 參數使用PHP 在MySQL 中處理預存程序時,取得由於文件有限,「 OUT”參數可能是一個挑戰。然而,這個過程可以透過利用 mysqli PHP API 來實現。 使用mysqli$mysqli =...
    程式設計 發佈於2024-11-03
  • 在 Kotlin 中處理 null + null:會發生什麼事?
    在 Kotlin 中處理 null + null:會發生什麼事?
    在 Kotlin 中處理 null null:會發生什麼事? 在 Kotlin 中進行開發時,您一定會遇到涉及 null 值的場景。 Kotlin 的 null 安全方法眾所周知,但是當您嘗試新增 null null 時會發生什麼?讓我們來探討一下這個看似簡單卻發人深省的情況吧! ...
    程式設計 發佈於2024-11-03
  • Python 字串文字中「r」前綴的意思是什麼?
    Python 字串文字中「r」前綴的意思是什麼?
    揭示「r」前綴在字串文字中的作用在Python中創建字串文字時,你可能遇到過神秘的“r” ” 前綴。此前綴具有特定的含義,可能會影響字串的解釋,尤其是在處理正則表達式時。“r”前綴表示該字串應被視為「原始」字串。 &&&]在常規字串中,轉義序列如\ n 和\t 被解釋為表示特殊字符,例如換行符和製表...
    程式設計 發佈於2024-11-03
  • 如何解決舊版 Google Chrome 的 Selenium Python 中的「無法找到 Chrome 二進位」錯誤?
    如何解決舊版 Google Chrome 的 Selenium Python 中的「無法找到 Chrome 二進位」錯誤?
    在舊版Google Chrome 中無法使用Selenium Python 查找Chrome 二進位錯誤在舊版Google Chrome 中使用Python 中的Selenium 時,您可能會遇到以下錯誤:WebDriverException: unknown error: cannot find ...
    程式設計 發佈於2024-11-03
  • `.git-blame-ignore-revs` 忽略批量格式變更。
    `.git-blame-ignore-revs` 忽略批量格式變更。
    .git-blame-ignore-revs 是 2.23 版本中引入的一项 Git 功能,允许您忽略 git Blame 结果中的特定提交。这对于在不改变代码实际功能的情况下更改大量行的批量提交特别有用,例如格式更改、重命名或在代码库中应用编码标准。通过忽略这些非功能性更改,gitblame 可以...
    程式設計 發佈於2024-11-03
  • 掌握函數參數:JavaScript 中的少即是多
    掌握函數參數:JavaScript 中的少即是多
    嘿,開發者們! ?今天,讓我們深入探討編寫乾淨、可維護的 JavaScript 的關鍵方面:管理函數參數 太多參數的問題 你有遇過這樣的函數嗎? function createMenu(title, body, buttonText, cancellable, theme, fon...
    程式設計 發佈於2024-11-03
  • 如何使用 FastAPI WebSockets 維護 Jinja2 範本中的即時評論清單?
    如何使用 FastAPI WebSockets 維護 Jinja2 範本中的即時評論清單?
    使用FastAPI WebSockets 更新Jinja2 範本中的項目清單在評論系統中,維護最新的評論清單至關重要提供無縫維護的使用者體驗。當新增評論時,它應該反映在模板中,而不需要手動重新加載。 在Jinja2中,更新評論清單通常是透過API呼叫來實現的。然而,這種方法可能會引入延遲並損害使用者...
    程式設計 發佈於2024-11-03

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

Copyright© 2022 湘ICP备2022001581号-3