第四章 react-redux,@reduxjs/toolkit依赖,学习

redux系列文章目录

第一章 简单学习redux,单个reducer

第二章 简单学习redux,多个reducer

第三章 redux和react-redux,@reduxjs/toolkit依赖结合使用

第五章 两张图告诉你redux常使用的api有哪些

前言

本章将使用react-redux,@reduxjs/toolkit依赖创建一个简单cout计数页面

准备工作

准备一个react框架的环境

bash 复制代码
npx create-react-app  react-redux-template

下载依赖

bash 复制代码
npm i react-redux @reduxjs/toolkit

启动命令

bash 复制代码
npm start

准备目录文件,

页面:src/pages/count/index.js

redux的存放:src/redux/store.js和src/redux/counterReducer.js

详情代码

store.js

bash 复制代码
import { configureStore } from "@reduxjs/toolkit";
import countReducer from "./countReducer";
const store = configureStore({
  reducer: {
    counter: countReducer,
  },
})

export default store;

counterReducer.js

bash 复制代码
import { createSlice } from "@reduxjs/toolkit";

const countSlice = createSlice({
  name: "counter",
  //这里initialState一定到放对象object,不然报错
  initialState: {value: 0},
  reducers: {
    increment: (state) => {
        state.value +=1
    },
    decrement: (state) => {
        state.value-=1
    }
  },
}
)
export const {increment, decrement} = countSlice.actions
export default countSlice.reducer

count/index.js

bash 复制代码
import React from 'react'
import { useSelector, useDispatch } from 'react-redux'
import { increment, decrement } from '../../redux/countReducer'
export default function CountPage() {
    const count = useSelector(state => state.counter.value)
    const dispatch = useDispatch()

    return (
        <div>
            <br />
            <br />count:{count}
            <br />
            <button onClick={() => {
                dispatch(increment())
            }}>加+1</button>
            &nbsp;
            <button onClick={() => { dispatch(decrement()) }}>减-1</button>

        </div>
    )
}

src/index.js

bash 复制代码
import React from 'react';
import ReactDOM from 'react-dom/client';
import './index.css';
// import App from './App';
import CountPage from './pages/count';
import reportWebVitals from './reportWebVitals';
import { Provider } from 'react-redux';
import store from './redux/store';
const root = ReactDOM.createRoot(document.getElementById('root'));
root.render(
  <React.StrictMode>
    <Provider store={store}>
    <CountPage />
    </Provider>
  </React.StrictMode>
);

reportWebVitals();

提示:<Provider>很重要,引入store,这样整个应用都可以使用store相关hooks拿取数据

效果

react-redux存储状态

相关推荐
盐焗西兰花4 分钟前
鸿蒙学习实战之路-Reader Kit自定义字体最佳实践
学习·华为·harmonyos
0思必得06 分钟前
[Web自动化] Selenium处理滚动条
前端·爬虫·python·selenium·自动化
Misnice8 分钟前
Webpack、Vite、Rsbuild区别
前端·webpack·node.js
青茶3609 分钟前
php怎么实现订单接口状态轮询(二)
前端·php·接口
大橙子额1 小时前
【解决报错】Cannot assign to read only property ‘exports‘ of object ‘#<Object>‘
前端·javascript·vue.js
近津薪荼1 小时前
dfs专题5——(二叉搜索树中第 K 小的元素)
c++·学习·算法·深度优先
敏叔V5872 小时前
AI智能体的工具学习进阶:零样本API理解与调用
人工智能·学习
2501_941864962 小时前
科学方法论破解学习时间堆砌误区
学习
LYFlied2 小时前
从 Vue 到 React,再到 React Native:资深前端开发者的平滑过渡指南
vue.js·react native·react.js
爱喝白开水a2 小时前
前端AI自动化测试:brower-use调研让大模型帮你做网页交互与测试
前端·人工智能·大模型·prompt·交互·agent·rag