」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 使用 RxJS 和 React 進行狀態管理

使用 RxJS 和 React 進行狀態管理

發佈於2024-08-01
瀏覽:660

Image description

介紹

建立大型網路應用程式可能很棘手,尤其是當您有大量不同的資訊需要追蹤時。但別擔心,RxJS 可以為您提供協助!它就像一個非常酷的工具,可以幫助您在一個地方管理所有數據。

使用 RxJS,您可以創建應用程式的不同部分可以使用的稱為「資料流」的東西。它就像一條大河流經您的應用程序,使所有內容保持連接和同步。

在本文中,我們將向您展示如何使用 RxJS 建立真正易於管理且運作良好的 Web 應用程式。在本文結束時,您將了解如何使用 RxJS 來管理所有資料並建立更大更好的 Web 應用程式!

為什麼要使用 RxJS 進行狀態管理?

嘿,當您建立大型網頁應用程式並且需要追蹤大量不同的資訊時,您是否曾經感到困惑?這就是 RxJS 的用武之地!它就像一個非常酷的庫,可以幫助您在一個地方管理所有資料。

使用 RxJS,您可以建立應用程式不同部分可以使用的資料流。這有點像一條河流流經您的應用程序,使所有內容保持連接和同步。

RxJS 還可以幫助您將應用程式分解為更小的部分,就像在您的房子裡有不同的房間來放置不同的東西一樣。這樣,就可以更輕鬆地讓一切井井有條並找到您需要的內容。

整體而言,RxJS 是管理大型 Web 應用程式中資料的絕佳工具。無論您是建立一個簡單的應用程式還是一個非常大的應用程序,RxJS 都可以幫助您控制一切!

待辦事項清單範例

應用新技術或新概念證明的最簡單方法是列出待辦事項清單。

商店:

const subject = new Subject();

const initialState: Task[] = [];

let state = initialState;

export const todoStore = {
  init: () => {
    subject.next(state);
  },
  subscribe: (setState: any) => {
    subject.subscribe(setState);
  },
  addTask: (content: string) => {
    const task = {
      content,
      id: uid(),
      isDone: false,
    };
    state = [...state, task];
    subject.next(state);
  },
  removeTask: (id: string) => {
    const tasks = state.filter((task) => task.id !== id);
    state = tasks;
    subject.next(state);
  },
  completeTask: (id: string) => {
    const tasks = state.map((task) => {
      if (task.id === id) {
        task.isDone = !task.isDone;
      }
      return task;
    });
    state = tasks;
    subject.next(state);
  },
  initialState,
};

這段程式碼定義了一個簡單的存儲,用於使用 RxJS 管理待辦事項清單。該商店是使用主題實現的,並提供添加、刪除和完成任務的方法。

init 函數透過使用 subject.next(state) 將目前狀態發佈到主題來初始化儲存。通常在首次載入應用程式時呼叫此函數,以確保商店是最新的。

訂閱功能允許元件訂閱儲存中的變更。當 store 更新時,傳遞給 subscribe 的 setState 函數將使用更新後的狀態被呼叫。此函數通常由需要顯示商店目前狀態的元件使用。

總的來說,init 和 subscribe 是此程式碼中的兩個重要函數,使開發人員能夠使用 RxJS 管理待辦事項清單的狀態。

用法:

實現這種狀態管理很容易,最高層級做這個就可以了:

const [tasks, setTasks] = useState([]);

  useEffect(() => {
    todoStore.subscribe(setTasks);
    todoStore.init();
  });

此程式碼使用 React hooks 來訂閱並初始化一個使用 RxJS 管理待辦事項清單的商店。

useState 掛鉤會建立一個名為tasks 的狀態變數和一個名為setTasks 的函式來更新該狀態。傳遞給 useState 的 [] 參數將任務的初始值設為空數組。

useEffect鉤子用於訂閱和初始化todoStore。 todoStore.subscribe(setTasks) 行將 setTasks 函數訂閱到儲存中的變更。這意味著每當商店更新時,都會使用更新後的狀態呼叫 setTasks,任務也會隨之更新。

todoStore.init() 函數透過使用 subject.next(state) 將目前狀態發佈到主題來初始化儲存。

結論

就是這樣了!我們學習如何使用 RxJS 和 React 建立待辦事項清單應用程式。我們使用 RxJS 來管理應用程式的狀態,並使用 React 向使用者顯示當前狀態。

我們看到了 RxJS 如何提供一組強大的工具來管理狀態,包括可觀察量、運算子和主題。我們也學習如何使用像 useState 和 useEffect 這樣的 React hooks 來即時更新應用程式狀態。

透過結合 RxJS 和 React,我們建立了一個很酷的應用程序,易於使用和維護。我們學到了一些非常有價值的技能,我們可以用它們在未來建立更令人驚嘆的 Web 應用程式!

如果您覺得這篇文章太晦澀,請查看這些:

  • 原始碼:https://github.com/starneit/rxjs-state-poc
  • 示範:https://rxjs-poc.web.app/
版本聲明 本文轉載於:https://dev.to/starneit/state-management-with-rxjs-and-react-32km?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