百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

react-redux使用详解

liuian 2025-03-07 20:53 56 浏览

为什么需要react-redux

随着用户操作的复杂性,页面组件的增多,使得组件直接的状态维护和信息传递更加复杂,不利于维护。使用 redux 定义全局单一的数据 Store,可以自定义 Store 里面存放着哪些数据,整个数据结构也是自己清楚的。

react-redux是react官方退出的redux绑定库。react-redux将所有组件分为两大类:UI组件容器组件,其中所有容器组件包裹着UI组件,构成父子关系。容器组件负责和redux交互,里面使用redux API函数,UI组件负责页面渲染,不使用任何redux API。容器组件会给UI组件传递redux中保存对的状态(state)和操作状态的方法(action)。

redux数据流向

Action

Action 是把数据从应用传到 store 的有效载荷。它是 store 数据的唯一来源。一般来说你会通过 store.dispatch() 将 action 传到 store。每个action是一个对象,其中type代表着要执行的操作,payload表示要操作的数据。

export function IncrementAction (payload){
    return {
        type:'increment',
        payload
    }
}

export  function DecrementAction(payload){
    return {
        type: 'decrement',
        payload
    }
}

Reducer

Store 收到 Action 以后,必须给出一个新的 State,这样 View 才会发生变化。这种 State 的计算过程就叫做 Reducer。Reducer 是一个函数,它接受 Action 和当前 State 作为参数,返回一个新的 State。只要传入参数相同,返回计算得到的下一个 state 就一定相同。没有特殊情况、没有副作用,没有 API 请求、没有变量修改,单纯执行计算。


const initState ={
    count:0
}
function count_reducers(state={...initState},action){
    let count = state.count
    switch (action.type){
        case 'increment':
            return {count: count+1};
        case 'decrement':
            return {count: count-1};
        default:
            return {count:state.count};

    }
}

export default count_reducers;

Store

Store是将Action和Reducer联系在一起的对象。1)维持应用的 state;2)提供 getState() 方法获取 state;3)提供 dispatch(action) 方法更新 state;4)通过 subscribe(listener) 注册监听器。

import { createStore } from 'redux'
import countReducers from '../store/conunt_reducers'

const store = createStore(countReducers)

export default store

connect()

react-redux 提供connect方法,用于从 UI 组件生成容器组件。connect的意思,就是将这两种组件连起来。

import React from "react";
import { connect } from "react-redux";
import {IncrementAction, DecrementAction } from "../store/action";
const StoreTest = ({count,Increment,Decrement}) =>{
    const increment = () => {
        Increment()
    }
    const decrement = () => {
        Decrement()
    }

    return (
        

{count}

) } const mapStateToProps =state=> state ; const mapDispatchToProps = (dispatch)=>{ return { 'Increment':()=> dispatch(IncrementAction({})), 'Decrement':() => dispatch(DecrementAction({})), } } export default connect(mapStateToProps,mapDispatchToProps)(StoreTest);

mapStateToProps

将state映射到 UI 组件的参数(props)。

const  mapStateToProps =state=> state ;

mapDispatchToProps

将用户对 UI 组件的操作映射成 Action。

const  mapDispatchToProps = (dispatch)=>{
    return {
        'Increment':()=> dispatch(IncrementAction({})),
        'Decrement':() => dispatch(DecrementAction({})),
    }
}

Provider

负责将容器组件把UI组件包裹起来,提供store属性

import React from 'react';
import ReactDOM from 'react-dom';
import StoreTest from "./component/storeTest";
import store from '../src/store/store'
import {Provider} from "react-redux";

ReactDOM.render(
    
        
            
        
    ,
    document.getElementById('root')
);

相关推荐

qq轻聊版安卓版(qq轻聊版手机下载安装2019)

手机QQ与手机QQ轻聊版有的区别:QQ轻聊版是腾讯新推出的一个QQ版本,去除了普通QQ的各种广告和服务入口,主打聊天、社交功能,精简了QQ秀、魔法表情等一大堆乱七八糟的功能。QQ正式版绑有新闻弹窗、...

联想笔记本开机黑屏啥都不显示

一,联想笔记本电脑开机黑屏主要原因是内存,显卡和显示器故障。二,首先是内存接触不良导致的黑屏,一般用酒精棉擦干净然后清理灰尘后就能正常开机。三,如果是显卡和显示器故障导致的,只能送专业维修点或者售后处...

u盘启动盘iso模式装机(u盘启动器iso模式)
  • u盘启动盘iso模式装机(u盘启动器iso模式)
  • u盘启动盘iso模式装机(u盘启动器iso模式)
  • u盘启动盘iso模式装机(u盘启动器iso模式)
  • u盘启动盘iso模式装机(u盘启动器iso模式)
机箱风扇安装方向(机箱风扇安装方向怎么调)

没有1、一般机箱风扇是装在机箱前部的,将冷空气从前部吸入吹向主板上空,最后由电源风扇排出,形成对流。前面的风扇一般在硬盘托架处,后面的风扇一般在电源下面,键盘口上方。如果风扇安装颠倒,后进前出或者后进...

万能显卡驱动怎么安装(显卡万能驱动器下载)

win7系统安装NVIDIA显卡驱动的方法如下:一、首先在电脑桌面点击“开始”进入。二、进入后选择“计算机”选项。三、然后找到“系统属性”一项并点击进入。四、进入以后选择“设备管理器”选项。...

microsoft office2010激活码
  • microsoft office2010激活码
  • microsoft office2010激活码
  • microsoft office2010激活码
  • microsoft office2010激活码
重装系统diskgenius分区教程

由于硬盘重新分区,所以里面已经没有操作系统,需要使用U盘启动盘重装系统。将U盘启动盘插上分区后的电脑,开机时按启动热键,选择USB选项进入。进入PE系统后,选择U盘内的系统进行安装。等待系统安装,安装...

用win10易升无法更新系统(win10易升检测不出最新版本)

首先确保C盘有大于25G的剩余空间,再试试下面的方法:方法一:卸载所有第三方杀毒软件和管理软件后。重启Windows更新服务。方法为打开记事本,复制下列命令,并保存为“xxx.bat”文件...

联想一体机老款式(联想一体机老款式升级)

只要设备没有损坏,都可以继续使用。但是老式电脑的配置可能比较低,比如内存小,只有512Mb,硬盘小于40G,但CPU都是初级产品,所以操作起来并不显得慢。这是因为系统也是可以安装win2000系统,...

win10强制删除流氓软件(win10强制删除流氓文件)

Win10删除流氓软件步骤 1、在桌面找看能不能找到软件的快捷方式如果不能就打开开始菜单中选中要卸载的程序右键点点击属性。 2、弹出对话框,点击打开文件位置就是查找目标。 3、系统会自动找到安装软件的...

迅雷加速器官网(迅雷加速器官网入口)

以下是使用迅雷视频加速器(VIP会员版)的步骤:1.下载并安装迅雷软件,然后登录VIP会员账号。2.打开迅雷软件,选择“工具”-“视频加速器”。3.在弹出的窗口中,找到您要加速的视频文件,将其拖...

爱奇艺老旧版本大全(爱奇艺老版本2017)

播放过程中点右下角设置,就是一个方向盘一样的东西,播放器选择FLASH,解决了。告诉你,那是因为你的爱奇艺会员不仅在你的电脑登录过,还在你的手机也登录过,对不对,我就是,明明就是我一个用,我手机登,电...

win7升级win10工具下载(win7 升级win10工具)

安装win7系统,然后JiHuo,然后用win10镜像进行升级;在win10系统下,如果没有网卡驱动的话,先使用网卡版驱动精灵安装网卡驱动,再使用系统更新更新系统,一般就能解决;如果不能解决...

电脑驱动用什么软件好(电脑驱动app哪个好)

如果是我windows系统,有如下软件可自动匹配和安装驱动:1.驱动精灵http://www.drivergenius.com驱动之家网站十年专业数据积累,驱动支持度达到98%,是最常用的软件2、驱动...

internet选项打不开(internet选项打不开解决方法)

答edge浏览器打不开的设置方法:1、首先打开IE浏览器后,自动跳转到了Edge浏览器。2、下面来阻止它的跳转。打开Edge浏览器,点击右上角的三个圆点,选择“设置”。3、在左边菜单中选择“默认浏览器...