React 項目中使用 Redux 實現公共狀態共享

在 React 項目中使用 Redux 實現公共下拉選狀態共享并通知各組件更新的完整方案如下:


1. 安裝 Redux 必要依賴

npm install @reduxjs/toolkit react-redux

2. 創建 Redux Store 和 Slice

store/selectSlice.js
import { createSlice } from '@reduxjs/toolkit';const initialState = {value: 'default', // 默認值options: [{ value: 'opt1', label: 'Option 1' },{ value: 'opt2', label: 'Option 2' }]
};export const selectSlice = createSlice({name: 'select',initialState,reducers: {setSelectValue: (state, action) => {state.value = action.payload;},updateOptions: (state, action) => {state.options = action.payload;}}
});export const { setSelectValue, updateOptions } = selectSlice.actions;
export default selectSlice.reducer;
store/store.js
import { configureStore } from '@reduxjs/toolkit';
import selectReducer from './selectSlice';export const store = configureStore({reducer: {select: selectReducer}
});

3. 在應用頂層提供 Store

index.js
import React from 'react';
import ReactDOM from 'react-dom';
import { Provider } from 'react-redux';
import { store } from './store/store';
import App from './App';ReactDOM.render(<Provider store={store}><App /></Provider>,document.getElementById('root')
);

4. 創建公共下拉選組件

components/GlobalSelect.js
import { Select } from 'antd';
import { useDispatch, useSelector } from 'react-redux';
import { setSelectValue } from '../store/selectSlice';const GlobalSelect = () => {const dispatch = useDispatch();const { value, options } = useSelector((state) => state.select);return (<Selectvalue={value}onChange={(val) => dispatch(setSelectValue(val))}options={options}style={{ width: 200 }}/>);
};export default GlobalSelect;

5. 在任意子組件中響應狀態變化

components/DisplayComponent.js
import { useEffect } from 'react';
import { useSelector } from 'react-redux';const DisplayComponent = () => {const selectValue = useSelector((state) => state.select.value);useEffect(() => {console.log('下拉選值變化:', selectValue);// 這里可以執行數據獲取等副作用操作}, [selectValue]);return <div>當前選擇: {selectValue}</div>;
};export default DisplayComponent;

6. 在頁面中使用(完整示例)

App.js
import GlobalSelect from './components/GlobalSelect';
import DisplayComponent from './components/DisplayComponent';
import AnotherComponent from './components/AnotherComponent';function App() {return (<div style={{ padding: 20 }}><h2>公共區域下拉選</h2><GlobalSelect /><div style={{ marginTop: 50 }}><h3>組件1</h3><DisplayComponent /></div><div style={{ marginTop: 50 }}><h3>組件2</h3><AnotherComponent /></div></div>);
}export default App;

7. 異步數據加載示例(如需要)

// 在需要的地方dispatch異步action
import { useEffect } from 'react';
import { useDispatch } from 'react-redux';
import { updateOptions } from '../store/selectSlice';const DataLoader = () => {const dispatch = useDispatch();useEffect(() => {const fetchOptions = async () => {const res = await fetch('/api/options');const options = await res.json();dispatch(updateOptions(options));};fetchOptions();}, [dispatch]);return null;
};

關鍵實現原理說明:

  1. 狀態集中管理:所有下拉選相關狀態存儲在 Redux store 中
  2. 單向數據流
    • 下拉選變更 → dispatch action → store 更新 → 所有訂閱組件自動更新
  3. 組件通信
    • 任何組件都可以通過 useSelector 獲取最新值
    • 任何組件都可以通過 useDispatch 修改值

性能優化建議:

  1. 精細化訂閱:組件只訂閱需要的具體值

    // 只訂閱value變化(options變化不會觸發重渲染)
    const value = useSelector((state) => state.select.value);
    
  2. 使用memo:對子組件進行記憶化

    import { memo } from 'react';
    const MemoizedComponent = memo(DisplayComponent);
    
  3. 批量更新:多個狀態變更使用 redux-batched-actions


替代方案對比(Redux vs Context)

特性ReduxContext API
適用場景中大型應用小型應用
調試工具強大的Redux DevTools無內置工具
性能自動淺比較優化需要手動優化
學習曲線較高較低
異步處理內置Thunk/Saga支持需自行實現

對于需要全局共享且頻繁更新的狀態(如公共下拉選),Redux 仍然是更專業的選擇。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/916758.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/916758.shtml
英文地址,請注明出處:http://en.pswp.cn/news/916758.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

徹底清理ArcGIS 10.2殘留的步驟

文章目錄前言一、徹底清理ArcGIS 10.2殘留的步驟總結前言 提示&#xff1a;這里可以添加本文要記錄的大概內容&#xff1a; 提示&#xff1a;以下是本篇文章正文內容&#xff0c;下面案例可供參考 一、徹底清理ArcGIS 10.2殘留的步驟 &#x1f527; 徹底清理ArcGIS 10.2殘留的…

JDK主流版本及推薦版本

根據當前Java生態發展&#xff08;截至2025年7月&#xff09;&#xff0c;結合主流企業實踐、技術特性和支持周期&#xff0c;以下是JDK主流版本及推薦版本的詳細分析&#xff1a;&#x1f9e9; 一、主流JDK版本現狀??JDK 8 (LTS)????使用比例??&#xff1a;約30-35%&a…

如何從 Web2 轉型到 Web3

如何從 Web2 轉型到 Web3如何從 Web2 轉型到 Web3引言Web2 與 Web3 的核心差異轉型的實用步驟1. 打基礎&#xff1a;學區塊鏈和 Web3 概念2. 學核心技術棧&#xff1a;從 Solidity 到 dApp3. 重新設計產品&#xff1a;混合模式起步4. 應對坑&#xff1a;技術、監管和安全5. 建社…

RuoYi-Vue 項目 Docker 容器化部署 + DockerHub 上傳全流程

本文詳細記錄本人在實際項目從 RuoYi-Vue 二次開發到 Docker 鏡像打包、DockerHub 上傳、異地一鍵部署的完整實戰全過程。涵蓋前后端打包產物準備、SQL初始化、docker-compose 管理、DockerHub 鏡像上傳、Gitee 代碼管理、子模塊大坑、數據庫404等所有可能出錯細節&#xff0c;…

【C語言進階】題目練習

目錄 1.箭形圖案 思路&#xff1a; 代碼&#xff1a; 2. 公務員面試 分析&#xff1a; 代碼 &#xff1a; 3. 判斷結構體大小&#xff08;1&#xff09; 答案&#xff1a; 分析&#xff1a; 4.判斷結構體大小&#xff08;2&#xff09; 答案: 分析: 5.宏定義計算…

Blender入門筆記——建模篇(二)

前言 在數字建模的世界中&#xff0c;快捷鍵和高效的操作是提高工作效率的關鍵。本手冊為您提供了常用的建模快捷鍵及操作技巧&#xff0c;幫助您在各種建模軟件中更加得心應手。無論是進行點、線、面操作&#xff0c;還是調整視圖、切換模式&#xff0c;這些快捷方式都將成為…

sqlite3學習---基礎知識、增刪改查和排序和限制、打開執行關閉函數

目錄 一、數據庫基礎知識 1.分類 2.名詞 3.嵌入式數據庫 4.特點 5.sqlite3的安裝 5.1在線安裝 5.2編譯 5.3驗證是否安裝成功 5.4sqlite3的使用 6.創建一個數據庫 7.系統維護命令 二、數據庫的創建和刪除 1.創建一個表 1.1用法 1.2代碼示例 2.刪除一個表 2.1用…

Class24AlexNet

Class24AlexNet AlexNet AlexNet于2012年ImageNet 圖像識別挑戰賽&#xff08;ILSVRC-2012&#xff09;中以 top-5 錯誤率15.3%獲得冠軍&#xff0c;遠遠領先第二名。它首次在大型圖像數據集上證明了深層卷積神經網絡的強大能力。 AlexNet 的總體結構 AlexNet 總共有 8 層具有學…

枚舉中間位置高級篇

參考資料來源靈神在力扣所發的題單&#xff0c;僅供分享學習筆記和記錄&#xff0c;無商業用途。 核心思路&#xff1a;參考枚舉中間位置基礎篇-CSDN博客 力扣題單練習(靈神題單中摘取題目) 447. 回旋鏢的數量 核心思路&#xff1a; 因給出的點都不相同&#xff0c;所以不會…

主數據管理系統能代替數據中臺嗎?

目錄 一、主數據管理系統≠數據中臺 1. 主數據管理系統&#xff1a;管的是 “不變的核心數據” 2. 數據中臺&#xff1a;管的是 “流動中的價值” 二、為什么企業更該先建 MDM&#xff1f; 1. 數據中臺解決不了數據本身問題 2. MDM 可以解決常見的基礎問題 3. 數字化轉型…

Nmap 終極教程:安裝、常用命令及法律法規指南

Nmap 終極教程&#xff1a;安裝、常用命令及法律法規指南 Nmap&#xff08;Network Mapper&#xff09;是一款強大的 網絡掃描和安全審計工具&#xff0c;廣泛用于滲透測試、網絡探測和系統管理。本教程涵蓋 安裝方法、常用命令詳解、輸出解析 以及 法律法規注意事項&#xff…

開源嵌入式數組引擎TileDB的簡單使用

TileDB 是C編寫的存儲和訪問通用多維數組引擎&#xff0c;它的官方Github網站https://github.1git.de/TileDB-Inc/TileDB 1.下載源代碼和二進制庫 源代碼https://github.1git.de/TileDB-Inc/TileDB/archive/refs/tags/2.28.1.tar.gz 選擇符合你的機器CPU架構和操作系統的庫 二進…

AI對服務器行業的沖擊與啟示:從挑戰走向重構

更多云服務器知識&#xff0c;盡在hostol.comAI&#xff08;人工智能&#xff09;技術的迅猛發展&#xff0c;已深刻影響了多個行業&#xff0c;服務器行業亦不例外。在過去&#xff0c;服務器的主要任務是簡單地提供存儲、計算和傳輸數據的服務。然而&#xff0c;隨著AI的崛起…

基于三臺主機搭建 Web 服務環境:Nginx、NFS 與 DNS 配置全流程

基于三臺主機搭建 Web 服務環境&#xff1a;Nginx、NFS 與 DNS 配置全流程 一、引言 在當今數字化的時代&#xff0c;搭建一個穩定、高效的 Web 服務環境是許多開發者和運維人員的常見需求。本文將詳細介紹如何利用三臺主機搭建一個包含 Nginx、NFS 和 DNS 服務的 Web 環境&…

MySQL——MVCC

1.為什么需要MVCC在并發場景下&#xff0c;讀寫操作會面臨嚴重的沖突問題&#xff1a;1.讀操作如果遇到寫操作&#xff0c;要么“讀到未提交的臟數據”&#xff0c;要么“被寫操作阻塞&#xff08;等待鎖釋放&#xff09;”&#xff1b;2.寫操作如果遇到讀操作&#xff0c;要么…

數據結構第2問:什么是算法?

算法 算法是一組用于解決具體問題的、明確的、有序的步驟或規則&#xff0c;能夠在有限的時間內通過這些步驟得到問題的答案。 算法的5個重要特性&#xff1a; 有窮性&#xff1a;算法必須在有限的步驟內結束&#xff0c;不能無限循環&#xff0c;保證最終能夠得到結果。確定性…

12-大語言模型—Transformer 打地基,下游任務蓋出百樣房,指標來驗收|下游任務白話指南

目錄 1、核心邏輯&#xff1a;Transformer 的 “語言處理閉環” 2、轉導與感知 → 模型咋 “理解語言”&#xff1f; 2.1、 人類 vs 機器的 “語言理解邏輯” 2.2、 自注意力機制&#xff1a;模型 “理解語言” 的數學核心 2.2.1、通俗拆解 2.2.1.1、是什么&#xff1f; …

深入探索爬蟲與自動化腳本:釋放效率的利器

在當今信息爆炸的時代&#xff0c;高效獲取和處理數據已成為核心競爭力。爬蟲與自動化腳本正是解決這一痛點的關鍵技術——它們如同數字世界的勤勞助手&#xff0c;幫我們自動完成繁瑣重復的任務。下面我們來系統了解這兩項技術的核心要點、應用場景和最佳實踐。一、爬蟲與自動…

React函數組件的“生活管家“——useEffect Hook詳解

&#x1f3af; React函數組件的"生活管家"——useEffect Hook詳解 1. &#x1f31f; 開篇&#xff1a;從生活中的"副作用"說起 嘿&#xff0c;各位掘友們&#xff01;今天咱們來聊聊React函數組件里的一個“大管家”——useEffect Hook。你可能會問&#x…

python基礎:request請求Cookie保持登錄狀態、重定向與歷史請求、SSL證書校驗、超時和重試失敗、自動生成request請求代碼和案例實踐

Cookie保持登錄狀態cookie session鑒權機制 cookie是由web服務器保存在用戶瀏覽器&#xff08;客戶端&#xff09;上的小文本文件&#xff0c;他可以包含有關用戶的信息。無論何時用戶訪問到服務器&#xff0c;都會帶上該服務器的cookie信息&#xff0c;一般cookie都是有有效期…