React---day11

14.4 react-redux第三方庫

提供connect、thunk之類的函數


以獲取一個banner數據為例子

store

我們在使用異步的時候理應是要使用中間件的,但是configureStore 已經自動集成了 redux-thunk,注意action里面要返回函數

import { configureStore } from '@reduxjs/toolkit';//Redux Toolkit 推薦的創建 store 的方法,自動集成了開發工具和中間件。
import rootReducer from './reducer/reducer.js'//項目中所有 reducer 的集合
//configureStore 已經自動集成了 redux-thunk
const store = configureStore({ reducer: rootReducer });
export default store;

action

import { CHANGE_BANNERS } from './constant.js'   // 導入 action 類型常量
import axios from 'axios'                        // 導入 axios 用于發起 HTTP 請求// 普通 action creator,返回一個 action 對象
export const changeBannersAction = (data) => ({type: CHANGE_BANNERS,      // action 類型payload: data              // 傳遞的數據
});

**reducer:**我們是先寫了一個總的reducer,合并多個 reducer,生成根 reducer 并導出,用于 Redux 的全局狀態管理。

import { combineReducers } from 'redux';
import bannerReducer from './bannerReducer';const rootReducer = combineReducers({banner : bannerReducer
});export default rootReducer;

分reducer:bannerReducer

import { CHANGE_BANNERS } from "../constant"
// 初始化狀態
const initailState = {banner : []
}
// 據不同的 action 類型決定如何更新 state。
const bannerReducer = (state = initailState , action) => {switch(action.type){default:return state;}}export default bannerReducer;

constant:

定義一些常量

引入store:

import React from 'react';
import ReactDOM from 'react-dom/client';
import App from './App';
import store from './store';
// 引用provider將store進行傳遞
import { Provider } from 'react-redux';
const root = ReactDOM.createRoot(document.getElementById('root'));
root.render(<Provider store={store}><App /></Provider>
);

為什么要使用中間件???因為reducer必須是純函數,這意味著它不能直接處理異步操作,異步操作必須在action之后的中間件處理之后生成原始的action,這樣,reducer函數就能處理相應的action,從而改變state,更新UI。

thunk有什么缺點:

  • Redux Thunk 在處理異步操作時,通常需要編寫大量的樣板代碼。
  • Redux Thunk 將異步邏輯與 Redux 的 action 緊密耦合在一起。這意味著 action creator 不僅需要定義 action 類型,還需要處理異步邏輯。

saga:

引入:創建中間件,應用中間件,run中間件

import { configureStore } from '@reduxjs/toolkit';
import createSagaMiddleware from 'redux-saga';
import mySaga from './saga';
import rootReducer from './reducer';
// 創建saga中間件
const sagaMiddleware = createSagaMiddleware();
// 定義store:reducer+中間件
const store = configureStore({reducer: rootReducer,middleware: (getDefaultMiddleware) =>getDefaultMiddleware().concat(sagaMiddleware)
});
// 使用中間件
sagaMiddleware.run(mySaga);export default store;

saga.js中監聽actionTyp然后執行邏輯代碼

import {put, takeEvery} from 'redux-saga/effects'
import axios from 'axios'
import { FETCH_HOME_MULTIDATA } from './constant';
import { changeBannersAction } from './actionCreator';
// 定義異步函數:*
function* fetchHomeMultidata(){const res =  yield axios.get('http://123.207.32.32:8000/home/multidata')const  banner = res.data.data.banner.list;
//    發送yield put(changeBannersAction(banner))
}
// 監聽
function* mySaga(){yield takeEvery( FETCH_HOME_MULTIDATA, fetchHomeMultidata )
}export default mySaga;

redux-thunk
const store = configureStore({ reducer: rootReducer });
export default store;


**action**:

import { CHANGE_BANNERS } from ‘./constant.js’ // 導入 action 類型常量
import axios from ‘axios’ // 導入 axios 用于發起 HTTP 請求

// 普通 action creator,返回一個 action 對象
export const changeBannersAction = (data) => ({
type: CHANGE_BANNERS, // action 類型
payload: data // 傳遞的數據
});


**reducer:**我們是先寫了一個總的reducer,合并多個 reducer,生成根 reducer 并導出,用于 Redux 的全局狀態管理。

import { combineReducers } from ‘redux’;
import bannerReducer from ‘./bannerReducer’;

const rootReducer = combineReducers({
banner : bannerReducer
});

export default rootReducer;


分reducer:**bannerReducer**:

import { CHANGE_BANNERS } from “…/constant”
// 初始化狀態
const initailState = {
banner : []
}
// 據不同的 action 類型決定如何更新 state。
const bannerReducer = (state = initailState , action) => {
switch(action.type){
default:
return state;
}

}

export default bannerReducer;


constant:定義一些常量**引入store:**

import React from ‘react’;
import ReactDOM from ‘react-dom/client’;
import App from ‘./App’;
import store from ‘./store’;
// 引用provider將store進行傳遞
import { Provider } from ‘react-redux’;
const root = ReactDOM.createRoot(document.getElementById(‘root’));
root.render(



);


為什么要使用中間件???因為reducer必須是純函數,這意味著它不能直接處理異步操作,異步操作必須在action之后的中間件處理之后**生成原始的action,這樣,reducer函數就能處理相應的action,從而改變state,更新UI。**thunk有什么缺點:- Redux Thunk 在處理異步操作時,通常需要編寫大量的樣板代碼。
- Redux Thunk 將異步邏輯與 Redux 的 action 緊密耦合在一起。這意味著 action creator 不僅需要定義 action 類型,還需要處理異步邏輯。saga:引入:創建中間件,應用中間件,run中間件

import { configureStore } from ‘@reduxjs/toolkit’;
import createSagaMiddleware from ‘redux-saga’;
import mySaga from ‘./saga’;
import rootReducer from ‘./reducer’;
// 創建saga中間件
const sagaMiddleware = createSagaMiddleware();
// 定義store:reducer+中間件
const store = configureStore({
reducer: rootReducer,
middleware: (getDefaultMiddleware) =>
getDefaultMiddleware().concat(sagaMiddleware)
});
// 使用中間件
sagaMiddleware.run(mySaga);

export default store;


saga.js中監聽actionTyp然后執行邏輯代碼

import {put, takeEvery} from ‘redux-saga/effects’
import axios from ‘axios’
import { FETCH_HOME_MULTIDATA } from ‘./constant’;
import { changeBannersAction } from ‘./actionCreator’;
// 定義異步函數:*
function* fetchHomeMultidata(){
const res = yield axios.get(‘http://123.207.32.32:8000/home/multidata’)
const banner = res.data.data.banner.list;
// 發送
yield put(changeBannersAction(banner))
}
// 監聽
function* mySaga(){
yield takeEvery( FETCH_HOME_MULTIDATA, fetchHomeMultidata )
}

export default mySaga;

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

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

相關文章

OD 算法題 B卷【反轉每對括號間的子串】

文章目錄 反轉每對括號間的子串 反轉每對括號間的子串 給出一個字符串s&#xff0c; 僅含有小寫英文字母和英文括號’(’ ‘)’&#xff1b;按照從括號內到外的順序&#xff0c;逐層反轉每對括號中的字符串&#xff0c;并返回最終的結果&#xff1b;結果中不能包含任何括號&am…

如何做好一份技術文檔?從規劃到實踐的完整指南

如何做好一份技術文檔&#xff1f;從規劃到實踐的完整指南 &#x1f31f; 嗨&#xff0c;我是IRpickstars&#xff01; &#x1f30c; 總有一行代碼&#xff0c;能點亮萬千星辰。 &#x1f50d; 在技術的宇宙中&#xff0c;我愿做永不停歇的探索者。 ? 用代碼丈量世界&…

css的定位(position)詳解:相對定位 絕對定位 固定定位

在 CSS 中&#xff0c;元素的定位通過 position 屬性控制&#xff0c;共有 5 種定位模式&#xff1a;static&#xff08;靜態定位&#xff09;、relative&#xff08;相對定位&#xff09;、absolute&#xff08;絕對定位&#xff09;、fixed&#xff08;固定定位&#xff09;和…

詳細講解Flutter GetX的使用

Flutter GetX 框架詳解&#xff1a;狀態管理、路由與依賴注入 GetX 是 Flutter 生態中一款強大且輕量級的全功能框架&#xff0c;集成了狀態管理、路由管理和依賴注入三大核心功能。其設計理念是簡潔高效&#xff0c;通過最小的代碼實現最大的功能&#xff0c;特別適合快速開發…

【大模型:知識庫管理】--Dify接入RAGFlow 知識庫

ragflow的官方文檔&#xff1a; HTTP API 接口 |抹布流 --- HTTP API | RAGFlow 接著前文&#xff0c;我們已經創建了知識庫&#xff0c;那么如何才能使用它呢&#xff1f; 當然也是通過網絡API的形式去調用它。本文將講解兩種方式&#xff1a; Dify調用python源碼調用 目錄…

Vue 模板配置項深度解析

Vue 模板配置項深度解析 在 Vue 組件開發中&#xff0c;template 是定義組件視圖結構的核心配置項。作為 Vue 專家&#xff0c;我將全面解析模板的各個方面&#xff0c;幫助你掌握高效構建 Vue 組件的藝術。 一、模板基礎概念 1. 模板的本質 聲明式渲染&#xff1a;描述 UI…

基于深度哈希與圖索引的十億級圖像近重復檢測系統

引言 在上一篇文章中,我們介紹了基于Vision API和SimHash的億級圖像去重方案。本文將更進一步,探討如何應對十億級圖像庫的近重復檢測挑戰,提出一種結合深度哈希學習與圖索引的創新架構。該系統在多個關鍵指標上比傳統方法提升顯著: 檢測精度提升:mAP@100達到0.92(傳統方…

Python開發基礎手語識別(基礎框架版)

一、前期準備 想要實現這些&#xff0c;首先就是要模擬出來一個大致的框架&#xff0c;方便后續開展&#xff0c;下面的就是隨便寫的一個框架&#xff0c;大家湊合看看就行&#xff0c;基本上是這個意思&#xff1a; from tkinter import *w Tk() w.title("手語識別&am…

React從基礎入門到高級實戰:React 實戰項目 - 項目一:在線待辦事項應用

React 實戰項目&#xff1a;在線待辦事項應用 歡迎來到本 React 開發教程專欄的第 26 篇&#xff01;在之前的 25 篇文章中&#xff0c;我們從 React 的基礎概念逐步深入到高級技巧&#xff0c;涵蓋了組件、狀態、路由和性能優化等核心知識。這一次&#xff0c;我們將通過一個…

1991-2024年上市公司個股換手率數據

1991-2024年上市公司個股換手率數據 1、時間&#xff1a;1991-2024年 2、來源&#xff1a;上海證券交易所和深圳證券交易所 3、指標&#xff1a;證券代碼、交易年份、開始日期、截止日期、年換手率(流通股數)(%)、年換手率(總股數)(%)、日均換手率(流通股數)(%)、日均換手率…

RAID存儲技術概述

1 數據存儲架構 數據存儲架構是對數據存儲方式、存儲設備及相關組件的組織和規劃&#xff0c;涵蓋存儲系統的布局、數據存儲策略等&#xff0c;它明確數據如何存儲、管理與訪問&#xff0c;為數據的安全、高效使用提供支撐。 1.1 存儲系統 存儲系統是計算機的重要組成部分之…

LRU 和 DiskLRU實現相冊緩存器

我是寫Linux后端的&#xff08;golang、c、py&#xff09;&#xff0c;后端緩存算法通常是指的是內存里面的lru、或diskqueue&#xff0c;都是獨立使用。 很少有用內存lru與disklru結合的場景需求。近段時間研究android開發&#xff0c;里面有一些設計思想值得后端學習。 寫這…

可視化預警:如何讓生產風險預警更高效?

你有沒有遇到過這種情況&#xff1f; 明明設備已經開始發熱報警&#xff0c;但操作人員還在繼續運行&#xff1b; 或者某個參數已經接近危險值&#xff0c;卻沒人注意到&#xff1b; 甚至問題早就埋下了隱患&#xff0c;只是當時沒發現…… 這些情況的背后&#xff0c;其實都…

【MPC-C++】qpOASES 源碼編譯與鏈接,編譯器設置細節

qpOASES 源碼編譯與鏈接 克隆源碼 git clone https://github.com/coin-or/qpOASES.gitcd qpOASES mkdir build cd build接下來是構建&#xff0c;有一些細節。 查看 CMakeLists.txt&#xff0c;發現如果不顯示指定 CMAKE_BUILD_TYPE 構建版本&#xff0c;會自動編譯 Release…

【11408學習記錄】考研數學攻堅:行列式本質、性質與計算全突破

行列式 數學線性代數一、對象&#xff08;元素&#xff09;&#xff1a;向量二、運算三、行列式3.1 第一種定義——行列式的本質定義3.2 行列式的性質性質1&#xff1a;行列互換&#xff0c;其值不變性質2&#xff1a;若行列式中某行&#xff08;列&#xff09;元素全為零&…

Qt/C++開發監控GB28181系統/取流協議/同時支持udp/tcp被動/tcp主動

一、前言說明 在2011版本的gb28181協議中&#xff0c;拉取視頻流只要求udp方式&#xff0c;從2016開始要求新增支持tcp被動和tcp主動兩種方式&#xff0c;udp理論上會丟包的&#xff0c;所以實際使用過程可能會出現畫面花屏的情況&#xff0c;而tcp肯定不丟包&#xff0c;起碼…

小木的算法日記-線段樹

&#x1f333; 線段樹 &#xff08;Segment Tree&#xff09;&#xff1a;玩轉區間作的終極利器 你好&#xff0c;未來的算法大師&#xff01; 想象一下&#xff0c;你正在處理一個巨大的數據集&#xff0c;比如某個電商網站一整天的用戶點擊流。老板突然問你&#xff1a;“下…

Day24 元組和OS模塊

1、元組&#xff08;有序 不可變 可重復&#xff09; 管道工程中pipeline類接收的是一個包含多個小元組的列表作為輸入。可以這樣理解這個結構&#xff1a; &#xff08;1&#xff09; 列表 []: 定義了步驟執行的先后順序。Pipeline 會按照列表中的順序依次處理數據。之所以用列…

Auto-Coder使用GPT-4o完成:在用TabPFN這個模型構建一個預測未來3天漲跌的分類任務

通過akshare庫&#xff0c;獲取股票數據&#xff0c;并生成TabPFN這個模型 可以識別、處理的格式&#xff0c;寫一個完整的預處理示例&#xff0c;并構建一個預測未來 3 天股價漲跌的分類任務 用TabPFN這個模型構建一個預測未來 3 天股價漲跌的分類任務&#xff0c;進行預測并輸…

Device Mapper 機制

Device Mapper 機制詳解 Device Mapper&#xff08;簡稱 DM&#xff09;是 Linux 內核中的一套通用塊設備映射框架&#xff0c;為 LVM、加密磁盤、RAID 等提供底層支持。本文將詳細介紹 Device Mapper 的原理、實現、內核配置、常用工具、操作測試流程&#xff0c;并配以詳細的…