react 学习之react toolkit状态管理

这只是个简单的例子

javascript 复制代码
首先这是store.ts
import { configureStore } from '@reduxjs/toolkit';
import { counterSlice } from './homeSlice';

// configureStore 创建store
export const store = configureStore({
  reducer: {
    home: counterSlice.reducer
  },
});
javascript 复制代码
counterSlice.ts
import { createAsyncThunk, createSlice } from '@reduxjs/toolkit';
const initialState = {
  value: 0
}
export const counterSlice = createSlice({
  name: 'counter',
  initialState,
  reducers: {
    increment: (state) => {
      state.value += 1;
    },
    decrement: (state) => {
      state.value -= 1;
    },
    reset:()=>{
      return { value: 3}
    }
  },
});
//虽然tookit 提供了返回值的处理api但是我还是喜欢在这里处理,个人写法习惯
export const getInfo = createAsyncThunk(
  'counter/getInfo',
  async (_, { dispatch }) => {
    const res = await new Promise(resolve => {
      setTimeout(() => {
        dispatch(counterSlice.actions.reset());
        resolve(2);
      }, 1000);
    });
    return null;
  }
);
javascript 复制代码
// 这是组件的一些调用方法
import { useDispatch, useSelector } from "react-redux";
import { counterSlice } from "../store/homeSlice"
import { useEffect } from "react"
import { getInfo } from "../store/homeSlice";
import { useNavigate } from "react-router-dom";

const Home = () => {
  let valueFromStore = useSelector((state:any) => state.home.value)
  const dispatch = useDispatch()
  const navigate = useNavigate()
  useEffect(() => {
    document.title = valueFromStore.toString();
    // 如果当这个值大于 5 的时候,我们就把这个值重置为 0
    if (valueFromStore > 5 || valueFromStore < 0) {
      dispatch(counterSlice.actions.reset())
    }
  }, [dispatch, valueFromStore]);
  // 调用counterSlice中的getInfo方法
  useEffect(() => {
    dispatch(getInfo() as any);
  }, [dispatch]); 
  const goToAbout = () => {
    navigate('/about');
    // navigate(-1); 返回上一页
  };
  return (
    <>
      <div>
        <button onClick={()=>dispatch(counterSlice.actions.decrement())}>加一</button>
        <button onClick={()=>dispatch(counterSlice.actions.increment())}>减一</button>
        <div>{valueFromStore}</div>
        <button onClick={goToAbout}>去About页面</button>
      </div>
    </>
  )
}
export default Home
javascript 复制代码
// 这是store的挂载部分,入口文件
import React from 'react';
import ReactDOM from 'react-dom/client';
import './index.css';
import App from './App';
import reportWebVitals from './reportWebVitals';
import { Provider } from 'react-redux'
import { BrowserRouter } from "react-router-dom";
import { store } from './store/store'

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

  </React.StrictMode>
);

好了,就这么多,每天学习一点点

相关推荐
寒秋花开曾相惜7 分钟前
(学习笔记)3.8 指针运算(3.8.3 嵌套的数组& 3.8.4 定长数组)
java·开发语言·笔记·学习·算法
猩猩程序员44 分钟前
Pretext:一个绕过 DOM 的纯 JavaScript 排版引擎
前端
竹林81844 分钟前
从“连接失败”到丝滑登录:我用 ethers.js 连接 MetaMask 的完整踩坑实录
前端·javascript
是翔仔呐1 小时前
第11章 显示外设驱动:I2C协议OLED屏、SPI协议LCD屏字符/图片/中文显示
c语言·开发语言·stm32·单片机·嵌入式硬件·学习·gitee
_李小白1 小时前
【AI大模型学习笔记之平台篇】第五篇:Trae常用模型介绍与性能对比
人工智能·笔记·学习
神舟之光1 小时前
jwt权限控制简单总结(乡村意见簿-vue-express-mongdb)
前端·vue.js·express
铭毅天下1 小时前
EasySearch Rules 规则语法速查手册
开发语言·前端·javascript·ecmascript
承渊政道1 小时前
【优选算法】(实战体会位运算的逻辑思维)
数据结构·c++·笔记·学习·算法·leetcode·visual studio
GISer_Jing1 小时前
AI Agent操作系统架构师:Harness Engineer解析
前端·人工智能·ai·aigc
英俊潇洒美少年1 小时前
css中专门用来提升渲染性能、减少重排重绘的属性
前端·css