一、redux是什么?

redux 就是react 全局状态管理,作用是存放全局数据

二、核心

  1. state:存放数据

  2. reducer:修改仓库数据

  • 是一个函数,参数一:仓库中的数据,参数2:行为 actions

  • 返回值就是 最新的仓库数据

  • 就是在reduce中定义的方法,修改数据,相当于mutations

  • 只能是同步方法

  1. actions:派发行为触发reducer; 语法:sotre.dispatch({type:'add'})

  2. 语法:

function  reducer( state={age:10,name:'lisa' },actions){
switch(action.type){
case "add":
return {...state, age:state.age+1 };
case "reduce":
return { age:state.age-1 }
default:
return state
}
}

三、使用redux

1、安装React-redux
# NPM
npm install redux # Yarn
yarn add redux
2、在src目录下创建store文件夹,index.js文件

在项目中使用到哪些api

  1. createStore

    • 作用:创建仓库

    • 语法:let store=createStore(reducer,中间件);

    • 输出store:

      • @@observable: ƒ observable() 观察仓库中的数据、

      • dispatch: ƒ dispatch(action) 触发reducer、

      • getState: ƒ getState()获取到仓库中的数据、

      • replaceReducer: ƒ replaceReducer(nextReducer) 替换reducer、

      • subscribe: ƒ subscribe(listener) 订阅

//创建仓库

import {createStore} from 'redux'

// createStore=>创建仓库
//语法
//let store = createStore(reducer,中间件) // reducer => 自己定义 // 1他是一个函数
// 2参数1 仓库中的数据 参数2 行为 actions
// 3这个reduer 返回值 就是最新的仓库中的数据
// 4redcuer =》就是在reducer中定义方法修改数据 =》vuex mutations function reducer(state={age:10},actions){
switch(actions.type){
case "add":
console.log('add',state);
return {age:state.age+1};
default :
return state
}
} let store = createStore(reducer) /**
*
* @@observable: ƒ observable() 观察仓库中的数据
dispatch: ƒ dispatch(action) =》触发reducer
getState: ƒ getState() =>获取到仓库中的数据
replaceReducer: ƒ replaceReducer(nextReducer) 替换reducer
subscribe: ƒ subscribe(listener) 订阅
*
*
*
* **/ export default store
3、在App.js根组件中使用仓库
  1. 在组件中使用仓库

    1. 引入仓库 import store from './store/index'

  2. 获取仓库中的数据:store.getState().meReducer.age; (meReducer.age指的是meReducer中的age属性)

  3. 触发reducer:store.dispatch({type:"add"})

import logo from './logo.svg';
import './App.css';
// 在组件中引入仓库
import store from './store/index'
import {useState} from 'react' function App() {
// 1获取到仓库中的数据
// console.log(store.getState());
// let age = store.getState().age
let [age,setAge] = useState(store.getState().age) const changeAge = ()=>{
//触发 reducer
store.dispatch({type:'add'})
// 问题=》仓库中的数据更新了=》但是视图没有更新 =》组件没有更新
// 1 讲这个数据=》动态数据
// setAge(仓库中的最新数据) =>和仓库进行关联
setAge(store.getState().age)
}
return (
<div className="App">
<h2>我的年龄{age}</h2>
<button onClick={()=>changeAge()}>修改仓库选中数据</button>
</div>
);
} export default App;

四、combineReducers 合并reducer

combineReducers:

  1. 作用:合并reducer

  2. 语法:let reducers = combineReducers({属性:各自的reducer, 属性:各自的reducer})

使用webpack中的api:require.context 自动获取到文件中的暴露的内容

  1. 作用:通过该函数可以获取一个上下文,从而实现工程自动化(遍历文件夹的文件,从中获取指定文件,自动导入模块)。在前端工程中,如果一个文件夹中的模块需要频繁引用时可以使用该中方式一次性引入

  2. 语法:let webf = require.context('文件路径',布尔值,正则)

返回值: 1 webf.keys() 返回一个数组,由匹配成功的文件所组成的数组 2 webf(路径).default 获取到路径中导出的模块

手动合并reducer

//  合拼reducer

import {combineReducers} from 'redux'

// combineReducers
import CartReducer from './CartReducer'
import meReducer from './meReducer'
//作用:合拼reducer
//语法: let reducers = combineReducers({属性:各自的reducer,属性:各自的reducer}) let reducers = combineReducers({
CartReducer,
meReducer
}) export default reducers

工程化处理reducer 合拼

/*
combineReducer
作用: 合并 reducer 数据实现模块化
语法:let reducers=combineReducers({属性:各自的reducer, 属性:各自的reducer})
*/ // 工程化处理Reducer 合拼 import { combineReducers } from "redux"; // combineReducers
import CartReducer from "./CartReducer";
import MeReducer from "./MeReducer";
// 在这里引入各自的reducer
// 处理方法 =》 自动引入reducer 自动合拼reducer // 1 在reducers文件夹下创建一个 reducer 文件 =》 再给我 合拼成reducer // 1 webpack =》 require.context =》自动获取到文件中的暴露内容 // 语法:require.context('文件路径',布尔值,正则)
// requeire.context('文件路径',布尔值,正则) => 返回值 (是webpack)实例方式 // 两个方法 1. webf.keys()=>['文件路径',布尔值,正则]
// 2.获取到它的内容 webf(路径).default let webf = require.context("./", true, /\.js/);
let webfList = webf.keys();
// console.log(webfList);
// 删除自身 index.js
let index=webfList.findIndex((item,index)=>{
return item=='./index.js'
})
webfList.splice(index,1)
// console.log(webfList); // 将webfList合并成一个对象
let objs={};
webfList.forEach((item,index)=>{// 文件路径 ./ CartReducer .js
// console.log(webf(item).default);
// 处理属性 = item
let items=item.replace('./','').replace('.js','')
// console.log(items)
objs[items]=webf(item).default
})
// console.log(objs) // 作用:合并reducer
// 语法:let reducers=combineReducers({属性:各自的reducer,属性:各自的reducer}) let reducers = combineReducers(objs); export default reducers;

五、bindActionCreators 自动触发reducer

  1. 作用:实现自动派发,实现行为 reducer 处理方法一一对应

  2. 语法:let 对象 = bindActionCreators({属性:属性值是一个方法},store.dispatch),属性值是一个方法 => 就是你的reducer中的方法

  3. 实现步骤:

/*
五:bindActionCreators bindActionCreators => 自动触发reducer => 你想要触发 语法:let 对象 =bindActionCreators({属性:属性值是一个方法},dispatch) 属性值是一个方法=》 就是你的reducers中的方法 使用:
1 实现reducer 和他的行为一一对应
2 使用 bindActionCreators 来实现
2.1 语法 bindActionsCreators({就是你的reducer 和 使用的行为对应},dispatch) 全部触发我的模板中的reducer 行为
1 我的模块reducer 有多少个行为
2 我的模块中add */ import { bindActionCreators } from "redux";
import store from "../index"; // bindActionCreators => 自动触发reducer => 你想要触发
// 语法 let对象 =bindActionCreators({属性:属性值是一个方法},dispatch),属性值是一个方法 =》就是你的reducer中的方法 // 创建方法
let meAdd = () => {
return {
// 行为 =》 actions
type: "add",
};
}; let meSub = () => {
return {
type: "sub",
};
}; let meActions = bindActionCreators({ meAdd, meSub }, store.dispatch); export default meActions;
  1. 引入这个自动派发的方法 :直接使用

import logo from './logo.svg';
import './App.css';
//来到组件
import store from './store/index'
import {useState} from 'react' //使用 自动派发
import meActions from './store/actions/meActions' function App() {
// 1获取到仓库中的数据
console.log(store.getState());
// let age = store.getState().meReducer.age
let [age,setAge] = useState(store.getState().meReducer.age) // 3引入我们这个自动派发的方法 =》直接使用
const changeAge = ()=>{
console.log( meActions);
// store.dispatch({type:'add'}) //触发reducer
meActions.meAdd() setAge(store.getState().meReducer.age)
} return (
<div className="App">
<h2>我的年龄{age}</h2>
<button onClick={()=>changeAge()}>修改仓库选中数据</button>
</div>
);
} export default App;

六、React Redux

1、为什么应该使用React-Redux?

因为React是一个独立的库,可以与React、Vue、Angular一直使用,但是它们是相互独立的;

如果想要同时使用 Redux 和 React,应该使用 React-Redux 来绑定这两个库

react-redux是连接react和redux 的桥梁,让react中使用redux时低耦合,方便快捷 react-redux 提供了两个 api

  1. 作用:提供全局组件和hooks,在父级组件提供仓库组件,在自己组件中获取到仓库的数据

  2. Provider 为后代组件提供 store

  3. connect 为组件提供数据和变更⽅法

核心:为我们react项目提供的一个组件,两个hooks

组件:Provider 1 作用:在父级组件中提供数据 ,其他的子集组件就可以获取到;

2 在父组件中提供了数据 store;

hooks:

useSelector 1 作用:在组件中获取仓库中的数据,再通过useState修改数据方法,让数据更新

2 语法:useSelector(state => { return 返回值}) // 返回 在仓库中获取的数据

useDispatch 1 作用:可以获取到更新组件的dispatch,先触发reducer,

2 语法:let dispatch=useDispatch(); dispatch({type:'add'});

2、在项目中使用redux

  1. 安装react-redux

npm install react-redux

  2.在入口文件中使用Provider提供仓库store

import React from 'react';
import ReactDOM from 'react-dom/client';
import './index.css';
import App from './App';
import { Provider } from 'react-redux';
import store from './store'; const root = ReactDOM.createRoot(document.getElementById('root'));
root.render(
<Provider store={store}>
{/* 在父组件中提供数据 */}
<App />
</Provider>
);

3.useSelector使用

4.useDispatch使用

/*
react-redux 作用
提供 1 组件 =》 在子级组件提供仓库组件,在自己组件中获取到仓库数据
2 hooks useSelector => 得到仓库中的数据
// 语法
useDispatch 作用:可以获取到更新组件的dispatch;触发 reducer =》 语法 useDispatch() => dispatch()
*/ // 使用
// 在自己组件中获取到仓库中的数据 =》 使用它提供的两个hooks
import {useSelector,useDispatch} from 'react-redux'
// useSelector(state=>{返回值}) =》返回值 得到仓库中的数据
// useDispatch 触发redcuer =》 语法 useDispatch()=> 的返回值就是 dispatch()
// 作用:获取到可以更新组件的dispatch function App(){
let age=useSelector(state=>{ // state是来自父组件的store数据
return state.MeReducer.age
}) let dispatch=useDispatch() // 1 先触发reducer,获取到仓库中的数据,再通过useState修改数据方法,让数据更新
console.log(age,'组件重新创建'); return(
<div>
<h2>我的年龄{age}</h2>
<button onClick={()=>{dispatch({type:'add'})}}>修改仓库</button>
</div>
) } export default App /*
总结:react-redux
作用:让仓库和react项目进行关联
它为react项目提供了一个组件(Provider),两个hooks(useSelector、useDispatch)
Provider: 在父级组件中提供数据,其他的自己组件就可以获取到
useSelector:在组件获取到仓库中的数据
useDispatch:先触发reducer,获取到仓库中的数据,再通过useState修改数据,让数据更新 */

七、异步actions

1、为什么需要处理异步?

因为reducer 只能处理同步问题,但是我们在工作中,可能需要在仓库中发生请求,获取到异步的数据

2、异步actions作用?

1)在仓库中获取异步收据 2)触发reducer 修改仓库中的数据

3、实现异步actions?
  1. 在store文件夹下创建一个 actions 文件夹,实现 异步actions 和各自的reducer 一一对应

//我的模块中 异步处理
import axios from 'axios'
import store from '../index'
// 定义异步处理方法 //根据actions作用来进行定义 =》1 获取到异步数据 2 触发reducer //定义异步处理方法
// 1 是一个方法
// 2 获取到异步数据
// 3 触发reducer => store
export function getAgeSub(){ //1获取到异步数据
function getData(){
return axios.get('').then(res=>{ //后端给的数据
let a = 100
return a
})
} // 2触发reducer
return async()=>{
// 1获取到异步数据
let data = await getData()
console.log(data);
// 2 触发reducer =>将异步数据传递给 reducer
console.log('触发reducer');
store.dispatch({type:'add',data })
}
} // getAgeSub() //总结 定义actions
//1 获取到异步数据
//2 触发reducer
//3 知道执行的获取到异步数据,再 执行reducer //定义异步actions => 函数劫持
//高阶函数=》 1 这个函数的参数是一个函数 或者 这个函数的返回值是一个函数
// 函数劫持 =》我在处理某个逻辑之前,要做一些操作,我们把这个方法叫做函数劫持
4 、在组件中使用 dispatch 触发异步actions

会报错 => 需要使用 1 中间件 2 redux-thunk

redux-thunk =》 作用1:处理异步action =》 给 异步action触发方法,第一个参数 就是dispatch

5、配置中间件 =》redux-thunk
  1. 在store/index.js 文件中进行配置

  2. 安装redex-thunk

npm install redux-thunk
// 引入中间件
import {createStore,applyMiddleware} from 'redux'
import reducers from './reducers'
// 引入'redux-thunk'
import ReduxThunk from 'redux-thunk' let store = createStore(reducers,applyMiddleware(ReduxThunk))
//applyMiddleware(ReduxThunk) =>1处理组件中 dispatch()这个方法内容可以写 方法
// 2 异步actions 返回的处理方法 的第一次参数就是dispatch export default store
6、在其他组件中触发异步actions

创建 异步actions 返回的处理方法 的第一次参数就是dispatch

export  function   getAgeReduce(){

    //1获取到异步数据
function getData(){
return axios.get('').then(res=>{ //后端给的数据
let a = 100
return a
})
} // 2触发reducer
return async(dispatch)=>{ //第一个参数 就是 dispatch
// 1获取到异步数据
let data = await getData()
console.log(data);
// 2 触发reducer =>将异步数据传递给 reducer
console.log('触发reducer'); dispatch({type:'reduce',data })
}
}

总结

react中redux怎么使用的更多相关文章

  1. react中redux的理解

    定义 redux可以看作是flux的进阶版,主要用于react中公共状态(数据)的管理 redux底层原理 redux有一个createStore方法,这个方法用户创建公共存储空间,createSto ...

  2. React中redux表单编辑

    reduxForm中反写数据在输入框中,数据是从别的模块拉取 // 编辑应用表单 class EditCode extends React.Component { constructor(props) ...

  3. react中Redux应用框架学习

    1. 最普通的react-redux 2.应用context的傻瓜组件和聪明组件的redux框架  3. 精简版react-redux,利用react-redux模块的redux(推荐)  4.多个模 ...

  4. 在React中使用Redux

    这是Webpack+React系列配置过程记录的第六篇.其他内容请参考: 第一篇:使用webpack.babel.react.antdesign配置单页面应用开发环境 第二篇:使用react-rout ...

  5. 教你如何在React及Redux项目中进行服务端渲染

    服务端渲染(SSR: Server Side Rendering)在React项目中有着广泛的应用场景 基于React虚拟DOM的特性,在浏览器端和服务端我们可以实现同构(可以使用同一份代码来实现多端 ...

  6. React 与 Redux 在生产环境中的实践总结

    React 与 Redux 在生产环境中的实践总结 前段时间使用 React 与 Redux 重构了我们360netlab 的 开放数据平台.现将其中一些技术实践经验总结如下: Universal 渲 ...

  7. immutable.js 在React、Redux中的实践以及常用API简介

    immutable.js 在React.Redux中的实践以及常用API简介 学习下 这个immutable Data 是什么鬼,有什么优点,好处等等 mark :  https://yq.aliyu ...

  8. react系列(五)在React中使用Redux

    上一篇展示了Redux的基本使用,可以看到Redux非常简单易用,不限于React,也可以在Angular.Vue等框架中使用,只要需要Redux的设计思想的地方,就可以使用它. 这篇主要讲解在Rea ...

  9. react中使用redux简易案例讲解

    为什么我想要使用redux? 前段时间初步上手了react,最近在使用react的过程中发现对于组件之间通信的需求比较迫切,尤其是在axios异步请求后端数据的时候,这样的需求是特别强烈的!举个例子: ...

  10. react中界面跳转 A界面跳B界面,返回A界面,A界面状态保持不变 redux的state方法

    在上一篇文章中说过了react中界面A跳到B,返回A,A界面状态保持不变,上篇中使用的是传统的localStorage方法,现在来使用第二种redux的state方法来实现这个功能 现在我刚接触red ...

随机推荐

  1. <二>自己实现简单的string

    我们结合运算符重载知识实现string 类 在自己实现的String类中可以参考C++中string的方法 例如构造,加法,大小比较,长度,[] 等操作. 当前的MyString 类中,暂时不加入迭代 ...

  2. i春秋Test

    点开是个莫名其妙的网站...看看源码, 第一排好像有点东西 最后也有点东西,所以我们直接百度海洋CMS漏洞(https://www.freebuf.com/vuls/150042.html) 所以这里 ...

  3. SSH SCP 使用秘钥验证 登录

    从Win10连接到Ubuntu 22.04. 1. Win10 上生成秘钥公钥 ssh-keygen -t rsa -C "xxx@yyy.com" 2. Ubuntu 22.04 ...

  4. 【Java EE】Day13 Web概念回顾、Tomcat、Servlet

    一.Web相关概念的回顾 1.软件架构 C/S B/S 2.资源分类 静态资源 所有用户访问得到相同结果 三剑客 浏览器通过静态解析引擎将从服务器接收到的静态资源显示到页面上 动态资源 不同用户访问得 ...

  5. 带你了解基于Ploto构建自动驾驶平台

    摘要:华为云Solution as Code推出基于Ploto构建自动驾驶平台解决方案. 本文分享自华为云社区<基于Ploto构建自动驾驶平台>,作者:阿米托福 . 2022年6月15日, ...

  6. Pointers and Constants

    Pointers and Constants char * const q = "abc"; // q is const *q = 'c'; // OK q++; //ERROR ...

  7. 04.Javascript学习笔记3

    1.箭头函数 箭头函数是一种更短的函数表达式. const age = birthyear => 2022 - birthyear; console.log(age(2000)) 箭头左边的bi ...

  8. 一个简单的工具开发:从学生端更新程序部署工具说起,浅谈qt中自定义控件制作和调用、TCP协议下文件的收发 、以及可执行文件的打包

    一个简单的工具开发:从学生端更新程序部署工具说起,浅谈qt中ui的使用和TCP协议下文件的收发.以及可执行文件的打包 写在前面,Qt Designer是一个非常操蛋的页面编辑器,它非常的...怎么说呢 ...

  9. C# Log4net配置文件 总结

    前言 因为项目日志太杂乱而且很大,打开一个就卡死了,何况用户电脑也扛不住日志积累,要做一个日志记录器管理日志.但对里面的配置有一些不熟悉(毕竟都是复制粘贴的),所以记录一下各个项的作用.方便后续复习. ...

  10. 基于容器的PaaS混合云的几种形式

    概述 这是 Gartner 的一个图,提供了全球的基于容器的 PaaS 公有云.混合云服务的梳理展示: 这里提供一个其他的视角: 中国市场,基于容器的 PaaS 混合云(公有云 + 私有云)的相关厂商 ...