[React] react-redux基本使用

文章目录

      • 1.redux
      • 2.安装redux
      • 3.操作redux
        • [3.1 创建最为核心的store](#3.1 创建最为核心的store)
        • [3.2 创建为store工作的reducer](#3.2 创建为store工作的reducer)
        • [3.3 redux的响应式处理](#3.3 redux的响应式处理)
      • 4.完整版redux
        • [4.1 完善actionCreators](#4.1 完善actionCreators)
        • [4.2 thunk中间件](#4.2 thunk中间件)
      • 5.react-redux
        • [5.1 Count容器组件](#5.1 Count容器组件)
        • [5.2 connect函数](#5.2 connect函数)
        • [5.3 Provider](#5.3 Provider)

1.redux

redux原理图

  1. actionCreators: actionCreators是redux运行的第一个角色,他将用户将要操作的内容包装成一个对象,{key:value},包装成一个{type:data},type为操作的类型,而data是操作具体的数值。
  2. store: store为redux最为核心的角色,虽然他接受actionCreators创造的对象,但实质并不是store去处理,而是store交给了他手下的reducers去处理,reducer处理完交给store保存和更新状态。
  3. reducers: reducer是redux整个工作中,处理状态的工作者,状态的处理最后都是交给了reducer去处理。

2.安装redux

bash 复制代码
npm i redux

redux并不是react官方创作,只不过redux和react配合更加出众,甚至在Vue以及Angular都可以用redux去管理状态,但在Vue中Vue开发者团队打造了一个更适合Vue的Vuex。

3.操作redux

3.1 创建最为核心的store
js 复制代码
import {createStore} from "redux"

export default createStore("这里要放入reducer")
3.2 创建为store工作的reducer
js 复制代码
import {INCREMENT, DECREMENT} from "../constant"

export default function countReducer(preState = 0, action) {
    const {type, data} = action
    switch (type) {
        case INCREMENT:
            return preState + data
        case DECREMENT:
            return preState - data
        default:
            return preState
    }
}

第一个参数为原始状态, 第二个参数为action对象, 一开始需要初始化状态, 所以指定state的初始值为0。

3.3 redux的响应式处理

在index.js中加入redux的监听。

js 复制代码
ReactDOM.render(<App />, document.getElementById("root"));

store.subscribe(() => {
  ReactDOM.render(<App />, document.getElementById("root"));
});

4.完整版redux

4.1 完善actionCreators
js 复制代码
import {INCREMENT,DECREMENT} from '../constant'

export const increment = data => ({type: INCREMENT, data})
export const decrement = data => ({type: DECREMENT, data})

export const asyncIncrement = (data, time) => {
    return dispatch => {
        setTimeout(() => {
            increment(data)
        }, time)
    }
}
4.2 thunk中间件

在redux中我们是不能让action成为一个函数, 但是在thunk中间件的基础上我们就可以redux支持异步函数式的action。

bash 复制代码
npm i redux-thunk

store.js

js 复制代码
import {createStore, applyMiddleware} from "redux"
import thunk from "redux-thunk"

export default createStore(countReducer,applyMiddleware(thunk))

5.react-redux

5.1 Count容器组件

容器组件是Count的UI和redux的桥梁, 容器组件拿到redux的状态然后通过props的方法传给reactUI组件使用, 如果UI组件要修改状态的话, 也是通过容器组件交给redux处理。

js 复制代码
import React, {Component} from "react";
import {connect} from "react-redux";
import {
    increment,
    decrement,
    asyncIncrement,
} from "../../actions/count";

class Count extends Component {
    increment = () => {
        const {value} = this.selectNumber;
        this.props.increment(value * 1);
    };

    decrement = () => {
        const {value} = this.selectNumber
        this.props.decrement(value * 1)
    }

    render() {
        return (
            <div>
                <h2>我是Count组件,下方组件总人数为:{this.props.personCount}</h2>
                <h4>当前求和为:{this.props.count}</h4>
                <select ref={(c) => (this.selectNumber = c)}>
                    <option value="1">1</option>
                    <option value="2">2</option>
                    <option value="3">3</option>
                </select>
                &nbsp;
                <button onClick={this.increment}>+</button>
                &nbsp;
                <button onClick={this.decrement}>-</button>
                &nbsp;
                {/*<button onClick={this.incrementIfOdd}>当前求和为奇数再加</button>*/}
                {/*&nbsp;*/}
                <button onClick={this.asyncIncrement}>异步加</button>
                &nbsp;
            </div>
        );
    }
}

// mapStateToProps mapDispatchToProps
export default connect(
    (state) => ({
        count: state.count,
        personCount: state.person.length,
    }),
    {increment, decrement, asyncIncrement}
)(Count);
5.2 connect函数

react-redux为我们提供这个函数, 构建容器组件, 进而构建桥梁。connect运用了函数的柯理化技术, 可以为UI组件传递redux的状态以及操作状态的方法。

mapStateToProps为第一个参数, mapDispatchToProps为第二个参数。为UI组件提供redux的状态和提供操作状态的方法提供操作状态的方法。

5.3 Provider

react-redux给我们提供的一个标签, 为后代提供store。

js 复制代码
import React from "react";
import ReactDOM from "react-dom";
import App from "./App";
import { Provider } from 'react-redux'
import store from "./redux/store";

ReactDOM.render(
    <Provider store={store}>
        <App/>
    </Provider>,
    document.getElementById("root")
);

之前的redux需要手动添加subscribe, 因为react-redux底层有特殊处理, 所以不用了。

相关推荐
闲坐含香咀翠6 小时前
告别二次登录!Web端检测并唤起Electron客户端实战
前端·客户端
岁月宁静7 小时前
都知道AI大模型能生成文本内容,那你知道大模型是怎样生成文本的吗?
前端·vue.js·人工智能
别看我只是一直狼7 小时前
从观察者模式到 RxJS:让复杂的异步逻辑变得优雅又舒服
javascript
花间相见7 小时前
【终端效率工具01】—— Yazi:Rust 编写的现代化终端文件管理器,告别繁琐操作
前端·ide·git·rust·极限编程
|晴 天|7 小时前
我如何用Vue 3打造一个现代化个人博客系统(性能提升52%)
前端·javascript·vue.js
风止何安啊7 小时前
网页都知道要双向握手才加载!从 URL 到页面渲染,单向喜欢连 DNS 都解析不通
前端·javascript·面试
太极OS7 小时前
给 AI Skill 做 CI/CD:GitHub + ClawHub + Xiaping 同步发布实战
前端
你_好7 小时前
Chrome 内置了 AI 工具协议?WebMCP 抢先体验 + 开源 DevTools 全解析
前端·mcp
GISer_Jing7 小时前
LangChain.js + LangGraph.js 前端AI开发实战指南
前端·javascript·langchain
正在发育ing__7 小时前
从源码看vue的key和状态错乱的patch
前端