redux中间件
Redux 中间件
什么是中间件?
中间件本质上就是一个函数,Redux允许我们通过中间件的方式,扩展和增强Redux应用程序,增强体现在对action处理能力上,之前的计数器与弹出框案例中。actions都是直接被reducer函数处理的,再加入了中间件以后,在出发了一个action之后这个action会优先被中间件处理,当中间处理完这个action以后,中间件会把这个action传递给reducer,让reducer继续处理
加入了中间件Redux 工作流程

开发Redux 中间件
开发中间件模版代码,本质上是一个函数,并且是一个科里化的一个函数
export default store => next => action => {}
这个函数中要求我们返回一个函数,在这个返回的函数中要求我们再返回一个函数,在最里层的函数中我们可以执行我们自己的业务逻辑,在最外层的函数中给我们提供了一个参数叫store,可以用store.getState获取当前state状态,也可以使用store.dispatch来触发另外一个action,至于干什么具体根据使用的业务逻辑来决定。在最里层的函数也有一个形参,这个形参就是组件触发的action对象,可以根据action.type来决定是否对当前action进行处理。中间的函数也有一个参数,这个参数是一个函数,我们称之为next,在我们执行完了逻辑代码之后,我们要去调用next方法,把当前action 传递给reducer,或者说传递给下一个中间件,因为中间件可以有多个。中间件开发好之后需要引入我们写的中间件并且注册给redux。
注册中间件
import { createStore, applyMiddleware } from 'redux'
import logger from './middlewares/logger'
createStore(reducer, applyMiddleware(
	logger
))
开发一个中间件
实现一个打印每次action操作的中间件
- 新建 src/store/middleware/logger.js 文件,在这个文件中导出一个中间件我们这里打印上
 
// eslint-disable-next-line import/no-anonymous-default-export
export default store => next => action => {
    console.log(store.getState())
    console.log(action)
    // next 必须调用  并且必须传第 action
    next(action)
}
- 在store/index.js 中注册中间件
 
import logger from './middleware/logger'
import { applyMiddleware } from 'redux'
export const store = createStore(RootReducer, applyMiddleware(logger))
这个时候中间件就可以使用了,运行项目可以看到中间件已经开始工作了,单个中间件已经注册好了,那么多个中间件怎么注册呢,多个中间件的运行顺序又是怎么样的呢,多个中间件就是在applyMiddleware的多个参数
- 我们新建 src/store/middleware/test.js 文件 注册另一个中间件这个test中间件打印一句话,并在store/index.js来注册中间件,并交换注册顺序来查看中间件执行顺序
 
//src/store/middleware/test.js
export default store => next => action => {
    console.log('test 中间件')
    next(action)
}
// src/store/index.js
import { createStore } from 'redux';
import RootReducer from './reducers/root.reducers'
import { applyMiddleware } from 'redux'
import logger from './middleware/logger'
import test from './middleware/test'
export const store = createStore(RootReducer, applyMiddleware(test  ,logger))
从上可以看出中间件的执行顺序就是注册顺序
通过中间件开发实例thunk
计数器新需求
点击+-按钮的时候延时2秒再执行
思路:在中间件拦截 加减操作的 action 等到事件到了之后再执行next方法
- 新建src/store/middleware/thunk.js 中间件,在这个中间件中拦截 +- 操作的action 延迟两秒再执行next方法,并在store/index.js文件中注册这个中间件
 
// src/store/middleware/thunk.js
import { INCREMENT, DECREMENT } from './../const/counter.const'
export default store => next => action => {
	  if (action.type === INCREMENT || action.type === DECREMENT) {
        setTimeout(() => {
            next(action)
        }, 2000)
    }else{
        next(action)
    }
}
// src/store/index.js  注册中间件
import thunk from './middleware/thunk'
export const store = createStore(RootReducer, applyMiddleware(test, logger, thunk))
这里虽然可以实现这个延迟执行这个功能,但是代码还不够灵活。中间件只关注是异步还是同步操作这样代码就灵活多了
- 改造中间件
 
- 当这个中间件函数不关心你想执行什么异步操作,只关心你执行的是不是异步操作
 - 如果你执行的是异步操作,再你触发action的时候,给中间件传递一个函数,如果执行的是同步操作就传递一个正常action对象
 - 异步操作代码要写在传递进来的函数中
 - 当前这个中间件的函数在点用你传递进来的函数时,要将dispatch方法传递进去
 
import { INCREMENT, DECREMENT } from './../const/counter.const'
export default store => next => action => {
    if (typeof action === 'function') {
        return  action(store.dispatch)
    }
    next(action)
}
- 在action中去新增加异步函数,并在视图中绑定事件的时候绑定异步函数
 
// src/store/actions/counter.actions.js
export const increment_async = payload => dispatch => {
    setTimeout(() => {
        dispatch(increment(payload))
    }, 2000);
}
// src/components/Count.js视图中更改绑定的事件
function Count({count,increment_async,decrement}) {
    return <div>
        <button onClick={() => increment_async(5)}>+</button>
        <span>{count}</span>
        <button onClick={() => decrement(5)}>-</button>
    </div>
}
这样我们并序需要在中间件中做具体异步操作,只需要在中间件中判断是异步还是同步操作,异步操作时执行我们传递进来的函数并传递 dispatch 给我们传递的异步函数,在异步函数中执行异步操作,并去触发真正的action动作
redux中间件的更多相关文章
- react+redux教程(七)自定义redux中间件
		
今天,我们要讲解的是自定义redux中间件这个知识点.本节内容非常抽象,特别是中间件的定义原理,那多层的函数嵌套和串联,需要极强逻辑思维能力才能完全消化吸收.不过我会多罗嗦几句,所以不用担心. 例子 ...
 - 【React全家桶入门之十三】Redux中间件与异步action
		
在上一篇中我们了解到,更新Redux中状态的流程是这种:action -> reducer -> new state. 文中也讲到.action是一个普通的javascript对象.red ...
 - redux中间件和redux-thunk实现原理
		
redux-thunk这个中间件可以使我们把这样的异步请求或者说复杂的逻辑可以放到action里面去处理,redux-thunk使redux的一个中间件,为什么叫做中间件 我们说中间件,那么肯定是谁和 ...
 - Redux 中间件与函数式编程
		
为什么需要中间件 接触过 Express 的同学对"中间件"这个名词应该并不陌生.在 Express 中,中间件就是一些用于定制对特定请求的处理过程的函数.作为中间件的函数是相互独 ...
 - 3.3 理解 Redux 中间件(转)
		
这一小节会讲解 redux 中间件的原理,为下一节讲解 redux 异步 action 做铺垫,主要内容为: Redux 中间件是什么 使用 Redux 中间件 logger 中间件结构分析 appl ...
 - 理解 Redux 中间件机制
		
Redux 的 action 是一个 JS 对象,它表明了如何对 store 进行修改.但是 Redux 的中间件机制使action creator 不光可以返回 action 对象,也可以返回 ac ...
 - Redux:中间件
		
redux中间件概念 比较容易理解. 在使用redux时,改变store state的一个固定套路是调用store.dispatch(action)方法,将action送到reducer中. 所谓中间 ...
 - react第十八单元(redux中间件redux-thunk,redux工程目录的样板代码,规范目录结构)
		
第十八单元(redux中间件redux-thunk,redux工程目录的样板代码,规范目录结构) #课程目标 中间件:中间件增强redux的可扩展性,实现功能复用的目的. redux-thunk异步逻 ...
 - redux 中间件 redux-saga 使用教程
		
redux 中间件 redux-saga 使用教程 redux middleware refs https://redux-saga.js.org/docs/ExternalResources.htm ...
 
随机推荐
- KingbaseES行转列(PIVOT)
			
如果以交叉表格式显示,则商业智能查询返回的数据通常是最有用的.SELECT语句的pivot_.数据透视是数据仓库中的一项关键技术.在其中,您可以将多行输入转换为数据仓库中较少且通常较宽的行.进行数据透 ...
 - KingbaseES应对表年龄增长过快导致事务回卷
			
背景 前几天碰到这样一个场景,在KingbaseES数据库当作数据同步节点.其特点是接收过来的数据量巨大,其更新超级频繁,最大的数据库达到6TB.这还不是主要的,主要导致问题发生原因是同步数据库有很多 ...
 - C++ | unordered_map 自定义键类型
			
C++ unordered_map 使用自定义类作为键类型 C++ unordered_map using a custom class type as the key
 - 【设计模式】Java设计模式 - 模板模式
			
Java设计模式 - 模板模式 不断学习才是王道 继续踏上学习之路,学之分享笔记 总有一天我也能像各位大佬一样 原创作品,更多关注我CSDN: 一个有梦有戏的人 准备将博客园.CSDN一起记录分享自己 ...
 - JS 模块化 - 03 AMD 规范与 Require JS
			
1 AMD 规范介绍 AMD 规范,全称 Asynchronous Module Definition,异步模块定义,模块之间的依赖可以被异步加载. AMD 规范由 Common JS 规范演进而来, ...
 - aspnetcore6.0源代码编译调试
			
虽然编译源码折腾了几个时间(卡在restore),最后还是跑起来了aspnetcore6.0mvc源码项目,下面说步骤,前提是网络能连外,对于不能连外的懒得折腾. 第一步 电脑找个地克隆下GitHub ...
 - ConfigMap使用说明
			
ConfigMap概述 ConfigMap供容器使用的典型用法如下. (1)生成为容器内的环境变量. (2)设置容器启动命令的启动参数(需设置为环境变量). (3)以Volume的形式挂载为容器内部的 ...
 - Windows上Navicat工具远程连接PostgreSQL数据库
			
首先,在pgdata(也就是在安装pg时指定的存放数据的文件见中)文件夹中,找到pg_hba.conf文件,在文件最后写入下面的内容: host all all 0.0.0.0/0 trust 接着, ...
 - v-infinite-scroll无限滚动
			
v-infinite-scroll="loadMore"表示回调函数是loadMore infinite-scroll-disabled="busy"表示由变量 ...
 - 持续集成指南:GitLab 的 CI/CD 工具配置与使用
			
前言 写代码这项工作,本质就是将工作自动化,减少手工操作提供效率,因为人的本质都是懒狗,程序员也不能例外,为了各种意义的效率提升(懒),我们需要持续集成工具,将代码测试.编译.发布这些重复性很高的工作 ...