」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 使用可重複使用列表元件擴展 React 應用程式

使用可重複使用列表元件擴展 React 應用程式

發佈於2024-11-01
瀏覽:831

Scaling React Apps with Reusable List Components

在 React 中构建可扩展的应用程序需要的不仅仅是可靠的业务逻辑。随着应用程序的发展,组件的架构对于其可维护性、性能和灵活性起着重要作用。许多 Web 应用程序中的基本任务之一是处理数据列表。无论是渲染产品列表、表格还是仪表板,您经常会遇到需要可重复和可重用列表结构的场景。

通过构建可重用的列表组件,您可以显着降低代码库的复杂性,同时提高可维护性和可扩展性。这篇博文将探讨如何在 React 中构建可重用的列表组件、为什么它对于扩展应用程序很重要,并提供大量代码示例来帮助指导您完成整个过程。

为什么可重用性对于扩展 React 应用程序很重要

可重用性是扩展 React 应用程序的关键。构建可重用的列表组件使您能够将通用逻辑和 UI 结构抽象为独立的组件,而不是重复代码来处理应用程序中的不同列表组件。这允许您的 React 组件模块化增长并防止代码重复,而代码重复可能会在您的应用程序扩展时导致潜在的错误和维护问题。

通过创建可重用的组件,您可以传入各种属性来控制列表的渲染,从而使您的应用程序更加动态和灵活,而无需为每个用例重写相同的逻辑。这种方法不仅使您的应用程序具有可扩展性,还通过简化代码可读性和可维护性来增强开发人员体验。

可重用列表组件的核心概念

要构建可扩展的可重用列表组件,您需要了解几个 React 概念:

Props 和 State:它们分别允许您将数据传递到组件并控制组件的内部行为。

数组方法:.map()、.filter() 和 .reduce() 等方法对于在 React 组件中转换数组至关重要。

组合优于继承:在 React 中,组合模式优于继承。您可以通过组合较小的可重用组件来构建复杂的 UI。

Prop-Driven UI:可重用的列表组件应该由 props 驱动。这允许您从父组件传递不同的数据、渲染逻辑甚至样式。

示例 1:一个简单的可重用列表组件

让我们首先创建一个简单的、可重用的列表组件,它可以接受项目数组作为 prop 并动态渲染它们:

import React from 'react';

const SimpleList = ({ items }) => {
  return (
    
    {items.map((item, index) => (
  • {item}
  • ))}
); }; export default SimpleList;

在此示例中,SimpleList 接受一个 items 属性,它是一个数组。我们使用 .map() 函数迭代数组并渲染无序列表中的每个项目 (

    )。每个项目都包含在
  • 元素中。 key 属性确保 React 可以在列表更改时有效地更新 DOM。

    用法示例:

    import React from 'react';
    import SimpleList from './SimpleList';
    
    const App = () => {
      const fruits = ['Apple', 'Banana', 'Orange', 'Mango'];
    
      return (
        

    Fruit List

    ); }; export default App;

    此示例呈现基本的水果列表。该组件足够灵活,您可以将任何数据数组传递给它。

    增强列表组件的可重用性

    虽然上面的例子很实用,但它非常有限。在现实应用程序中,您通常需要处理更复杂的要求,例如有条件地呈现列表项、应用自定义样式或向单个项目添加事件侦听器。

    让我们通过渲染属性允许自定义渲染逻辑,使 SimpleList 更具可重用性。

    示例 2:使用 Render Props 进行自定义列表渲染

    Render props 是 React 中的一种模式,允许您控制组件内渲染的内容。以下是如何使用此模式来允许自定义呈现列表项:

    const ReusableList = ({ items, renderItem }) => {
      return (
        
      {items.map((item, index) => (
    • {renderItem(item)}
    • ))}
    ); };

    在这种情况下,ReusableList 组件接受 renderItem 属性,它是一个接受项目并返回 JSX 的函数。这提供了一种灵活的方式来控制每个列表项的呈现方式。

    用法示例:

    const App = () => {
      const users = [
        { id: 1, name: 'John Doe', age: 30 },
        { id: 2, name: 'Jane Smith', age: 25 },
      ];
    
      return (
        

    User List

    (

    {user.name}

    Age: {user.age}

    )} />
    ); };

    在此示例中,renderItem 属性允许我们自定义每个用户的显示方式。现在我们可以为任何数据结构重用相同的列表组件,根据特定的用例呈现它。

    示例 3:使列表组件可通过高阶组件进行扩展

    React 中另一个强大的模式是高阶组件 (HOC)。 HOC 是一个函数,它接受一个组件并返回一个具有附加功能的新组件。

    例如,如果我们想通过数据获取或条件渲染等附加行为来增强 ReusableList,我们可以使用 HOC。

    const withLoading = (Component) => {
      return function WithLoadingComponent({ isLoading, ...props }) {
        if (isLoading) return 

    Loading...

    ; return ; }; };

    这里,withLoading HOC 向任何组件添加加载行为。让我们将其应用到我们的 ReusableList 中:

    const EnhancedList = withLoading(ReusableList);
    
    const App = () => {
      const [isLoading, setIsLoading] = React.useState(true);
      const [users, setUsers] = React.useState([]);
    
      React.useEffect(() => {
        setTimeout(() => {
          setUsers([
            { id: 1, name: 'John Doe', age: 30 },
            { id: 2, name: 'Jane Smith', age: 25 },
          ]);
          setIsLoading(false);
        }, 2000);
      }, []);
    
      return (
        

    User List

    (

    {user.name}

    Age: {user.age}

    )} />
    ); };

    在此示例中,withLoading HOC 包装了 ReusableList,为其添加了加载状态管理。此模式通过使用附加逻辑增强组件而无需修改原始组件,从而促进代码重用。

    示例 4:带 Hooks 的高级列表组件

    使用 React hooks,我们可以通过将状态逻辑直接集成到组件中,将可重用列表组件提升到另一个层次。让我们构建一个可以处理分页的可重用列表。

    const usePagination = (items, itemsPerPage) => {
      const [currentPage, setCurrentPage] = React.useState(1);
      const maxPage = Math.ceil(items.length / itemsPerPage);
    
      const currentItems = items.slice(
        (currentPage - 1) * itemsPerPage,
        currentPage * itemsPerPage
      );
    
      const nextPage = () => {
        setCurrentPage((prevPage) => Math.min(prevPage   1, maxPage));
      };
    
      const prevPage = () => {
        setCurrentPage((prevPage) => Math.max(prevPage - 1, 1));
      };
    
      return { currentItems, nextPage, prevPage, currentPage, maxPage };
    };
    

    usePagination 钩子封装了分页逻辑。我们现在可以在列表组件中使用这个钩子。

    const PaginatedList = ({ items, renderItem, itemsPerPage }) => {
      const { currentItems, nextPage, prevPage, currentPage, maxPage } = usePagination(
        items,
        itemsPerPage
      );
    
      return (
        
      {currentItems.map((item, index) => (
    • {renderItem(item)}
    • ))}
    ); };

    用法示例:

    const App = () => {
      const items = Array.from({ length: 100 }, (_, i) => `Item ${i   1}`);
    
      return (
        

    Paginated List

    {item}
    } />
    ); };

    此示例演示了一个分页列表,用户可以在其中浏览项目页面。该钩子处理所有分页逻辑,

    使其可在不同组件之间重用。

    结论

    在 React 中构建可重用的列表组件是创建可扩展应用程序的基本实践。通过抽象通用逻辑,使用渲染道具、高阶组件和钩子等模式,您可以创建适应不同用例的灵活、可扩展和可维护的列表组件。

    随着您的 React 应用程序的增长,采用可重用组件不仅可以简化您的代码库,还可以增强性能、减少冗余并实现新功能的快速迭代。无论您是处理简单的列表还是更复杂的 UI 需求,投入时间创建可重用组件从长远来看都会得到回报。

    参考

    React官方文档

    React 渲染道具

    反应高阶组件

    反应钩子

版本聲明 本文轉載於:https://dev.to/nilebits/scaling-react-apps-with-reusable-list-components-4ep6?1如有侵犯,請聯絡[email protected]刪除
最新教學 更多>
  • 如何使用Python的請求和假用戶代理繞過網站塊?
    如何使用Python的請求和假用戶代理繞過網站塊?
    如何使用Python的請求模擬瀏覽器行為,以及偽造的用戶代理提供了一個用戶 - 代理標頭一個有效方法是提供有效的用戶式header,以提供有效的用戶 - 設置,該標題可以通過browser和Acterner Systems the equestersystermery和操作系統。通過模仿像Chro...
    程式設計 發佈於2025-04-05
  • 為什麼使用固定定位時,為什麼具有100%網格板柱的網格超越身體?
    為什麼使用固定定位時,為什麼具有100%網格板柱的網格超越身體?
    網格超過身體,用100%grid-template-columns 為什麼在grid-template-colms中具有100%的顯示器,當位置設置為設置的位置時,grid-template-colly修復了? 問題: 考慮以下CSS和html: class =“ snippet-code”> ...
    程式設計 發佈於2025-04-05
  • 如何將來自三個MySQL表的數據組合到新表中?
    如何將來自三個MySQL表的數據組合到新表中?
    mysql:從三個表和列的新表創建新表 答案:為了實現這一目標,您可以利用一個3-way Join。 選擇p。 *,d.content作為年齡 來自人為p的人 加入d.person_id = p.id上的d的詳細信息 加入T.Id = d.detail_id的分類法 其中t.taxonomy ...
    程式設計 發佈於2025-04-05
  • Python讀取CSV文件UnicodeDecodeError終極解決方法
    Python讀取CSV文件UnicodeDecodeError終極解決方法
    在試圖使用已內置的CSV模塊讀取Python中時,CSV文件中的Unicode Decode Decode Decode Decode decode Error讀取,您可能會遇到錯誤的錯誤:無法解碼字節 在位置2-3中:截斷\ uxxxxxxxx逃脫當CSV文件包含特殊字符或Unicode的路徑逃...
    程式設計 發佈於2025-04-05
  • 如何將PANDAS DataFrame列轉換為DateTime格式並按日期過濾?
    如何將PANDAS DataFrame列轉換為DateTime格式並按日期過濾?
    將pandas dataframe列轉換為dateTime格式示例:使用column(mycol)包含以下格式的以下dataframe,以自定義格式:})指定的格式參數匹配給定的字符串格式。轉換後,MyCol列現在將包含DateTime對象。 date date filtering > = ...
    程式設計 發佈於2025-04-05
  • Java是否允許多種返回類型:仔細研究通用方法?
    Java是否允許多種返回類型:仔細研究通用方法?
    在Java中的多個返回類型:一種誤解類型:在Java編程中揭示,在Java編程中,Peculiar方法簽名可能會出現,可能會出現,使開發人員陷入困境,使開發人員陷入困境。 getResult(string s); ,其中foo是自定義類。該方法聲明似乎擁有兩種返回類型:列表和E。但這確實是如此嗎...
    程式設計 發佈於2025-04-05
  • 如何在php中使用捲髮發送原始帖子請求?
    如何在php中使用捲髮發送原始帖子請求?
    如何使用php 創建請求來發送原始帖子請求,開始使用curl_init()開始初始化curl session。然後,配置以下選項: curlopt_url:請求 [要發送的原始數據指定內容類型,為原始的帖子請求指定身體的內容類型很重要。在這種情況下,它是文本/平原。要執行此操作,請使用包含以下標頭...
    程式設計 發佈於2025-04-05
  • 如何在GO編譯器中自定義編譯優化?
    如何在GO編譯器中自定義編譯優化?
    在GO編譯器中自定義編譯優化 GO中的默認編譯過程遵循特定的優化策略。 However, users may need to adjust these optimizations for specific requirements.Optimization Control in Go Compi...
    程式設計 發佈於2025-04-05
  • eval()vs. ast.literal_eval():對於用戶輸入,哪個Python函數更安全?
    eval()vs. ast.literal_eval():對於用戶輸入,哪個Python函數更安全?
    稱量()和ast.literal_eval()中的Python Security 在使用用戶輸入時,必須優先確保安全性。強大的python功能eval()通常是作為潛在解決方案而出現的,但擔心其潛在風險。本文深入研究了eval()和ast.literal_eval()之間的差異,突出顯示其安全性含義...
    程式設計 發佈於2025-04-05
  • 如何同步迭代並從PHP中的兩個等級陣列打印值?
    如何同步迭代並從PHP中的兩個等級陣列打印值?
    同步的迭代和打印值來自相同大小的兩個數組使用兩個數組相等大小的selectbox時,一個包含country代碼的數組,另一個包含鄉村代碼,另一個包含其相應名稱的數組,可能會因不當提供了exply for for for the uncore for the forsion for for ytry...
    程式設計 發佈於2025-04-05
  • 版本5.6.5之前,使用current_timestamp與時間戳列的current_timestamp與時間戳列有什麼限制?
    版本5.6.5之前,使用current_timestamp與時間戳列的current_timestamp與時間戳列有什麼限制?
    在時間戳列上使用current_timestamp或MySQL版本中的current_timestamp或在5.6.5 此限制源於遺留實現的關注,這些限制需要對當前的_timestamp功能進行特定的實現。 創建表`foo`( `Productid` int(10)unsigned not ...
    程式設計 發佈於2025-04-05
  • 如何從PHP中的Unicode字符串中有效地產生對URL友好的sl。
    如何從PHP中的Unicode字符串中有效地產生對URL友好的sl。
    為有效的slug生成首先,該函數用指定的分隔符替換所有非字母或數字字符。此步驟可確保slug遵守URL慣例。隨後,它採用ICONV函數將文本簡化為us-ascii兼容格式,從而允許更廣泛的字符集合兼容性。 接下來,該函數使用正則表達式刪除了不需要的字符,例如特殊字符和空格。此步驟可確保slug僅包...
    程式設計 發佈於2025-04-05
  • 如何使用Regex在PHP中有效地提取括號內的文本
    如何使用Regex在PHP中有效地提取括號內的文本
    php:在括號內提取文本在處理括號內的文本時,找到最有效的解決方案是必不可少的。一種方法是利用PHP的字符串操作函數,如下所示: 作為替代 $ text ='忽略除此之外的一切(text)'; preg_match('#((。 &&& [Regex使用模式來搜索特...
    程式設計 發佈於2025-04-05
  • 如何有效地轉換PHP中的時區?
    如何有效地轉換PHP中的時區?
    在PHP 利用dateTime對象和functions DateTime對象及其相應的功能別名為時區轉換提供方便的方法。例如: //定義用戶的時區 date_default_timezone_set('歐洲/倫敦'); //創建DateTime對象 $ dateTime = ne...
    程式設計 發佈於2025-04-05
  • 如何正確使用與PDO參數的查詢一樣?
    如何正確使用與PDO參數的查詢一樣?
    在pdo 中使用類似QUERIES在PDO中的Queries時,您可能會遇到類似疑問中描述的問題:此查詢也可能不會返回結果,即使$ var1和$ var2包含有效的搜索詞。錯誤在於不正確包含%符號。 通過將變量包含在$ params數組中的%符號中,您確保將%字符正確替換到查詢中。沒有此修改,PD...
    程式設計 發佈於2025-04-05

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

Copyright© 2022 湘ICP备2022001581号-3