如何提高redux開發效率?當然是redux-tookit啦!

来源:https://www.cnblogs.com/wangtianzhen/archive/2023/10/08/17748272.html
-Advertisement-
Play Games

前言 使用react-redux的朋友都經歷過這種痛苦吧? 定義一個store倉庫,首先創建各種文件,比如reducer、action、store...,然後 將redux和react連接使用。整個流程繁瑣,寫起來代碼冗餘。 react-redux創建倉庫,文件目錄如下: 好懷念使用 vuex創建寫 ...


前言

使用react-redux的朋友都經歷過這種痛苦吧?

定義一個store倉庫,首先創建各種文件,比如reducer、action、store...,然後 將redux和react連接使用。整個流程繁瑣,寫起來代碼冗餘。

react-redux創建倉庫,文件目錄如下:
image.png

好懷念使用 vuex創建寫倉庫的日子.......
直到有一天我發現了redux-toolkit ,原來redux還能這樣寫呀!

什麼是redux-toolkit

redux-toolkit 是官方推薦的編寫redux邏輯的方法,簡化了redux的配置過程,無需再創建actions、reducer的,更大程度方便使用redux倉庫

基本使用

redux-toolkit的使用步驟,可分為如下5步

  • 1、安裝 redex-toolkit
  • 2、創建slices
  • 3、創建store
  • 4、將Redux連接到React應用(provide)
  • 5、在React組件中使用(useSelector、useDispath)

環境配置

vscode
React Redux Toolkit RTK Quer
安裝npm

npm i redux react-redux @reactjs/toolkit

創建切片 slices

一個切片是一個包含 reducer 函數和 action creator 的對象。它定義了一部分狀態和與該狀態相關的操作。

// sliceTbale.js

import { createSlice } from '@reduxjs/toolkit';

const moviesSlice = createSlice({
  name: 'movies',
  // c初始化狀態
  initialState: {
    currentData:[],// 
    tableData:[]
  },  
  reducers: {
      delete_table: (state, { payload }) => { 
            // 通過篩選實現刪除 
             state.currentTable = state.currentTable.filter((item:{id:any})=>{
                return item.id !== payload.id
             }) 
             state.table =  state.currentTable
             message.success('刪除成功') 
        },
  },
});

export const { addMovie } = moviesSlice.actions; // 導出 action creator
export default moviesSlice.reducer; // 導出 reducer

創建倉庫-store

我們使用 configureStore 函數來創建 Redux Store,並使用剛剛創建的 reducer 將切片與 Store 關聯起來。

// 創建store倉庫
import { configureStore } from "@reduxjs/toolkit";
import  initTable  from "./module/table";

const reduxStore = configureStore({
    reducer: {
        // xxx: xxx,
        table:initTable
    },
})

export default reduxStore

redux鏈接react

完成以上步驟,redux配置ok啦,如何讓整個項目中應用redux呢?
使用Provider包裹 React頂層組件,將 Redux store 對象傳遞給組件樹中的所有組件,使得 Redux 的狀態管理能夠在整個應用程式中生效。
打開項目的入口文件 index.tsx,代碼如下:

import React from 'react';
import ReactDOM from 'react-dom/client';
import './index.css';
import RouterConfig from './router/routerConfig';
import RouterView from './router/routerView';
import "nprogress/nprogress.css" // 樣式
import { Provider } from 'react-redux';
import reduxStore from './store';

const root = ReactDOM.createRoot(
  document.getElementById('root') as HTMLElement
);
root.render(
  <React.StrictMode>
    <Provider store={reduxStore}> 
      <RouterView config={RouterConfig}></RouterView>
    </Provider>
  </React.StrictMode>
);

組件中使用redux

使用狀態和操作:在組件中,可以使用 useSelector 和 useDispatch 鉤子來訪問狀態和觸發 action。

import React, { useEffect, useState } from 'react';
import { useDispatch, useSelector } from 'react-redux';

interface IndexProps {}

const Index: React.FC<IndexProps> =  (props) => {
  //  獲取redux倉庫數據
  const tableState = useSelector((state:any)=>state.table)
   // 創建redux 派發器
  const Dispath = useDispatch()
  console.log('table倉庫數據',tableState)  
  return (
    <> 
      {tableState.currentData.length}
     </>
  );
};

export default Index;

進階使用

redux中如何執行非同步呢?
createAsyncThunk 創建非同步操作, 通常用於發出非同步請求。
createAsyncThunk 創建一個非同步action,方法觸發的時候會有三種狀態:

  • pending(進行中)
  • fulfilled(成功)
  • rejected(失敗)
export const getMovieData:any = createAsyncThunk('sliceTable/getMovie', 
  async () => {
    const res= await getMovieListApi();
    return res;
  }
);

完整示例

import { createSlice, createAsyncThunk } from "@reduxjs/toolkit";
import { getMovieListApi } from "../../API/home";
 import { message } from "antd";
// // createAsyncThunk 創建非同步操作, 通常用於發出非同步請求。
// createAsyncThunk 創建一個非同步action,方法觸發的時候會有三種狀態:
// pending(進行中)、fulfilled(成功)、rejected(失敗)
export const getMovieData: any = createAsyncThunk('sliceTable/getMovie',
    async () => {
        const res = await getMovieListApi();
        return res;
    }
);

const sliceName = createSlice({
    name: "sliceTable",
    initialState: {
        table: [],
        currentTable: []
    },
    reducers: {
        initTable: (state, { payload }) => {
            // console.log('初始化sliceTable數據')
        },
        delete_table: (state, { payload }) => { 
            // 通過篩選實現刪除 
             state.currentTable = state.currentTable.filter((item:{id:any})=>{
                return item.id !== payload.id
             }) 
             state.table =  state.currentTable
             message.success('刪除成功') 
        },
        serach_table: (state, { payload }) => { 
            // 通過篩選實現刪除 
            console.log('payload',payload)
             state.currentTable = state.table.filter((item:{name:string})=>{
                return item.name.includes(payload)
             })  
        },
        
    },
    // 讓 slice 處理在別處定義的 actions, // 包括由 createAsyncThunk 或其他slice生成的actions
    extraReducers: builder => builder
        .addCase(getMovieData.pending, (state, { payload }) => {
            // state.loading = true
            console.log('非同步請求 中')
        })
        .addCase(getMovieData.fulfilled, (state, { payload }) => {
            // state.loading = false
            console.log('拿到非同步數據')
            state.table = payload.data.data.list
            state.currentTable = payload.data.data.list
        })
        .addCase(getMovieData.rejected, (state, { payload }) => {
            // state.loading = false
            // state.error = payload
            console.log('非同步操作錯誤')
    
        })

})


export const { initTable,delete_table ,serach_table} = sliceName.actions
export default sliceName.reducer

extraReducers
// extraReducers 欄位讓 slice 處理在別處定義的 actions, // 包括由 createAsyncg 或其他slice生成的actions。

store 映射到組件props中

使用 connect 函數將 store 內的數據映射到組件 props內

image-20231007232652559

讀者朋友好呀,我是王天~

嘗試做過很多事情,汽修專業肄業生,半路出道的野生程式員、前端講師、新手作者,最終還是喜歡寫代碼、樂於用文字記錄熱衷分享~

如文章有錯誤或者不嚴謹的地方,期待給於指正,萬分感謝。

如果喜歡或者 有所啟發,歡迎 star,對作者也是一種鼓勵。

微信:「wangtian3111」,加我進王天唯一的讀者群。

個人博客:https://itwangtian.com

95後、自學編程工作3年、向上生長
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 上一篇內容《從2PC和容錯共識演算法討論zookeeper中的Create請求》介紹了保證分散式事務提交的兩階段提交協議,而XA是針對兩階段提交提出的介面實現標準,本文則對XA進行介紹 ...
  • 背景 在lodash函數工具庫中,防抖_.debounce和節流_.throttle函數在一些頻繁觸發的事件中比較常用。 防抖函數_.debounce(func, [wait=0], [options=]) 創建一個 debounced(防抖動)函數,該函數會從上一次被調用後,延遲 wait 毫秒後 ...
  • 1.font-style 設置字體樣式 屬性值: normal:指定⽂本字體樣式為正常的字體 italic:指定⽂本字體樣式為斜體。 2.文字字體 font-family 只能引用系統自帶的字體樣式,如果需要其他別的字體,需要從外部下載調用 引用外部字體 網站:https://font.chinaz ...
  • 這裡給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 問題 最近公司項目上遇到了掃碼槍因搜狗/微軟/百度/QQ等輸入法在中文狀態下,使用掃碼槍掃碼會丟失字元的問題 思考 這種情況是由於掃碼槍的硬體設備,在輸入的時候,是模擬用戶鍵盤的按鍵來實現的字元輸入的,所以會觸發輸入法的中文模式,並且也會 ...
  • 參考資料 calc() - CSS:層疊樣式表 | MDN Getting started - Escaping | Less.js Using The CSS Function calc() Inside The LESS CSS Preprocessor 問題描述 在原生 CSS 中有以下的函數 ...
  • 正則表達式是一個強大的文本匹配工具。但是,對於初學者來說,眾多的符號和規則可能讓人難以理解。其實,你不需要記住所有的正則表達式語法!本文將分享一些簡單而實用的技巧,幫助理解正則表達式的核心概念,輕鬆使用正則表達式! 基礎入門 概念 正則表達式(Regular Expression,在代碼中常簡寫為r ...
  • 本文介紹如何在vue中定義插件,註冊插件和使用插件 插件目錄 /src/plugins 插件入口文件 /src/plugins/index.js import cache from './cache' import modal from './modal' // 安裝預設插件,在main.js中引入 ...
  • 數據驗證 數據驗證應該是正則表達式最常見的場景了,經常用於用戶的輸入是否符合所需的條件。數據驗證可確保輸入或導入的數據準確、一致,並符合預定義的規則。 驗證手機號: const phoneNumber = "13712345678"; const regex = /^1[3-9]\d{9}$/; c ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...