」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 增強 React 清單渲染:乾淨且可重複使用的模式

增強 React 清單渲染:乾淨且可重複使用的模式

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

Enhancing React List Rendering: A Clean and Reusable Pattern

身為 React 開發人員,我們都遇過需要渲染資料清單的場景。雖然 .map() 方法效果很好,但每次渲染清單時重複相同的邏輯可能會讓人筋疲力盡,並導致程式碼重複。幸運的是,有一種更乾淨、可擴展的方法來處理這個問題,使用可重複使用元件、高階元件或自訂掛鉤。

在本文中,我將分享一種改進 React 中清單渲染的方法,確保您的程式碼保持 DRY、可重複使用且更易於維護。

主要問題:重複的.map()邏輯

假設您正在為電子商務應用程式建立儀表板。儀表板包含多個清單:最近訂單、最暢銷產品、用戶評論等。您需要使用 .map() 函數呈現每個清單。這是一個典型的例子:

const orders = [...]; // Array of order data

return (
  
    {orders.map((order, index) => (
      
    ))}
  >
);

現在,您可以看到每個清單都重複 .map() 邏輯,類似的程式碼使您的元件變得混亂。這就是可重複使用模式可以派上用場的地方。

解決方案:可重複使用的ListComponent

為了避免重複 .map() 邏輯,我們可以建立一個可重複使用的 ListComponent 來抽象化映射邏輯,並允許我們根據資料渲染不同的元件。

function ListComponent({ data, renderItem }) {
  return (
    
      {data.map((item, index) => renderItem(item, index))}
    >
  );
}

用法:

 (
    
  )} 
/>

在此模式中:
renderItem:定義每個項目應如何呈現的函數

透過傳遞不同的 renderItem 函數,我們可以為任何清單重複使用 ListComponent。這會產生一個乾淨、可重複使用的元件,減少重複的 .map() 邏輯。

更有彈性:高階組件(HOC)

如果多個元件需要列表渲染,讓我們透過建立一個高階元件來進一步採用此模式。 HOC 允許透過附加功能增強任何元件 - 在本例中為清單渲染。

function withListRendering(WrappedComponent) {
  return function ListWrapper({ data, ...props }) {
    return (
      
        {data.map((item, index) => (
          
        ))}
      >
    );
  };
}

用法:

const EnhancedOrderComponent = withListRendering(OrderComponent);

// Now render the component with any data array

透過使用 withListRendering HOC 包裝 OrderComponent,我們自動新增了清單渲染行為,而無需修改原始元件。這種模式使程式碼保持模組化。

對於 Hook 愛好者:用於列表渲染的自訂 Hook

React hooks 提供了一種封裝邏輯的函數式方法。如果您喜歡使用鉤子,這裡是使用自訂鉤子渲染清單的範例。

function useListRenderer(data, renderItem) {
  return data.map((item, index) => renderItem(item, index));
}

用法:

function OrdersDashboard({ orders }) {
  const orderList = useListRenderer(orders, (order, index) => (
    
  ));

  return {orderList}>;
}

這種方法將 .map() 邏輯移到鉤子中,使渲染邏輯與元件的結構分開。這是保持組件精簡並專注於演示的另一種方法。

現實場景:電子商務儀表板

讓我們將此模式應用在現實場景中。想像一下,您正在建立一個電子商務管理儀表板,其中需要呈現多個訂單、產品、評論等清單。

使用 ListComponent 方法,您可以呈現以下訂單清單:

 (
    
  )} 
/>

當我們需要渲染不同的清單(例如產品)時,相同的 ListComponent 可以與不同的 renderItem 函數重複使用:

 (
    
  )} 
/>

無需重寫 .map() 邏輯 - 只需將 ListComponent 與不同的資料和元件重複使用即可。這使得程式碼庫在成長時更易於維護。

結論:乾淨、可重複使用且可擴展的程式碼

可重複使用的 ListComponent 模式透過抽象重複的 .map() 邏輯來簡化 React 清單渲染。無論您喜歡使用基本組件方法、HOC 還是自訂掛鉤,此模式都可確保程式碼乾淨且可重複使用。

建立具有多個清單的 React 元件,請考慮使用其中一種模式來使元件專注於表示,同時將清單邏輯分離到外部。

您發現 React 中還有哪些其他有用的可重複使用模式?請在評論中告訴我! 最後感謝您的閱讀

版本聲明 本文轉載於:https://dev.to/readwanmd/enhancing-react-list-rendering-a-clean-and-reusable-pattern-1d94?1如有侵犯,請聯絡[email protected]刪除
最新教學 更多>
  • 實施訂單處理系統:建立基礎部分
    實施訂單處理系統:建立基礎部分
    1. Introduction and Goals Welcome to the first part of our comprehensive blog series on implementing a sophisticated order processing system ...
    程式設計 發佈於2024-11-08
  • 理解 JavaScript 數組迭代方法
    理解 JavaScript 數組迭代方法
    我最近遇到一個面試問題,要求使用不同的方法來迭代 JavaScript 陣列物件。提示最初看起來很簡單,因為我需要提供一些範例程式碼片段。然而,這個問題引起了我的興趣,所以我決定更深入地研究每種方法,不僅探索如何使用它們,而且探索何時以及為何選擇一種方法而不是另一種方法。 在本文中,我將引導您了解...
    程式設計 發佈於2024-11-08
  • 如何在 Galera 叢集節點上設定 MariaDB/MySQL Exporter 以進行 Prometheus 監控
    如何在 Galera 叢集節點上設定 MariaDB/MySQL Exporter 以進行 Prometheus 監控
    社群開發者您好! ? 在這篇文章中,我將引導您完成在 Galera Cluster 節點上設定 MariaDB/MySQL Exporter 以使用 Prometheus 進行監控所採取的步驟。就我而言,我在具有三個節點的雲端伺服器供應商上運行 MariaDB Galera Cluster,並使用...
    程式設計 發佈於2024-11-08
  • 示範疼痛
    示範疼痛
    我想講述一件每次我需要做的事情時都困擾我的事情。它正在準備演示。一般來說,當我嘗試使用 Viktor Lidholt 的 slick_slides 來準備簡報時,我會在 PowerPoint 中準備簡報。  如何放置不同大小的圖像,如何選擇字體,使用什麼顏色,如何放置程式碼,如何突出顯示它,所有這些...
    程式設計 發佈於2024-11-08
  • 請求 Iris 的正文限制中間件
    請求 Iris 的正文限制中間件
    概述 Iris Body Limit 中間件是一個強大的工具,用於控制 Iris Web 應用程式中傳入請求正文的大小。透過設定請求正文的大小限制,您可以防止用戶端發送過大的負載,否則可能會壓垮您的伺服器或導致拒絕服務 (DoS) 攻擊。此中間件對於處理檔案上傳、JSON 有效負載...
    程式設計 發佈於2024-11-08
  • 如何在 cookie 中儲存 PHP 陣列以及安全性和序列化的最佳實踐是什麼?
    如何在 cookie 中儲存 PHP 陣列以及安全性和序列化的最佳實踐是什麼?
    在 Cookie 中儲存 PHP 陣列在 PHP 中,可以將陣列儲存在 Cookie 中,以便在後續請求時輕鬆檢索。然而,考慮安全隱患並使用正確的序列化技術至關重要。 序列化選項要將陣列轉換為cookie 相容格式,您可以選擇以下方法:JSONsetcookie('your_cookie_name'...
    程式設計 發佈於2024-11-08
  • 如何設定VS Code調試工作目錄?
    如何設定VS Code調試工作目錄?
    設定VS Code 中偵錯的工作目錄在Visual Studio Code (VS Code) 中偵錯Python 程式時,它通常很有用指定腳本應在其中執行的工作目錄。這允許您使用與程式碼所在的特定目錄相關的檔案和資源。 要將工作目錄動態設定為目前開啟的Python 檔案的目錄,請修改launch....
    程式設計 發佈於2024-11-08
  • 嬰兒學步學習 Laravel
    嬰兒學步學習 Laravel
    歡迎回來,開發者! ✨ 在Laravel 之旅的這一章中(請記住,我在撰寫這些文章時正在學習,因此這將是您能找到的最現實的教程系列之一!),我們將深入研究我們的Laravel 專案。我們將探索專案結構,熟悉遷移,並以最簡單的方式分解 MVC 架構。 ?今天的議程:...
    程式設計 發佈於2024-11-08
  • 如何動態包含具有不受控制的「document.write()」內容的腳本?
    如何動態包含具有不受控制的「document.write()」內容的腳本?
    動態新增具有不受控制的來源內容的腳本標記當內容來自於控制項外部時,建立具有外部來源的腳本標記可能會帶來挑戰包括使用document.write() 的程式碼。如前所述,僅在 中附加 script 標記無法支援此類內容。 要解決此問題,請考慮以下解決方案:使用 document.create 新建一...
    程式設計 發佈於2024-11-08
  • 在 JavaScript 中如何有效地確定一個數字是否為素數?
    在 JavaScript 中如何有效地確定一個數字是否為素數?
    在 JavaScript 中高效驗證素數在電腦程式設計中,決定給定數字是否是質數是一項基本任務。質數是大於 1 的正整數,除了 1 和它本身之外沒有正因數。 檢查素數的一種流行方法涉及埃拉托斯特尼篩法。然而,出於效能考慮,可以採用更有效的方法,如以下 JavaScript 實作所示:let inpu...
    程式設計 發佈於2024-11-08
  • 為什麼 Lambda 表達式需要最終局部變數而不是實例變數?
    為什麼 Lambda 表達式需要最終局部變數而不是實例變數?
    Lambda 表達式與變數作用域:為什麼Local ≠ Instance在Java 中使用lambda 表達式時,一個常見的困惑點是為什麼局部變數需要終結,而實例變數需要終結不要。本文旨在闡明這種差異背後的根本原因。 局部變數:最終性指令在 lambda 表達式中,局部變數必須標記為 Final 以...
    程式設計 發佈於2024-11-08
  • CKA 全程課程日 為什麼要使用 Kubernetes?
    CKA 全程課程日 為什麼要使用 Kubernetes?
    那么,您可能已经使用 Docker 容器有一段时间了,对吧?我知道旋转第一个容器的兴奋感就像魔法一样,但随后现实袭来。您开始注意到大规模管理容器很快就会成为物流噩梦。就在那时,Kubernetes(K8s)像经验丰富的项目经理一样进入房间,准备接管并简化一切。 在这篇文章中,我们将探讨独立容器面临的...
    程式設計 發佈於2024-11-08
  • 簡要封裝範例
    簡要封裝範例
    書包: 這個範例會建立一個名為 bookpack 的包,其中包含一個用於管理書籍資料庫的簡單類別。 圖書類別: 它有私有屬性 title、author 和 pubDate(標題、作者和出版日期)。 構造方法初始化屬性。 show() 方法顯示書籍詳細資料。 BookDemo類別: 建立一個包...
    程式設計 發佈於2024-11-08
  • 適用於 AWS 雲端的簡單 SaaS 的技術堆疊
    適用於 AWS 雲端的簡單 SaaS 的技術堆疊
    介绍 注1:这里是托管的交互式演示:demo.saasconstruct.com 注 2:我每个 SaaS 设置的每月账单为 3-5 美元,其中大部分是 CI/CD 成本。 注3:模板在这里:saasconstruct.com。 我在 AWS 上完成了多个 AI PoC 和 MVP...
    程式設計 發佈於2024-11-08
  • 為什麼在事件處理程序中使用箭頭函數時「this」會出現意外行為?
    為什麼在事件處理程序中使用箭頭函數時「this」會出現意外行為?
    JavaScript - 箭頭函數與事件處理程序當使用箭頭函數作為事件處理程序的回調時,函數中的 this 值是意外的。這篇部落格文章解釋了此行為背後的原因,並提供了使用event.currentTarget.箭頭函數和詞法作用域存取預期元素的解決方案與常規函數不同,箭頭函數沒有其自己的上下文或範圍...
    程式設計 發佈於2024-11-08

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

Copyright© 2022 湘ICP备2022001581号-3