Redux的梳理
学习Redux之前,我了解了它需要去解决什么问题:
- 用户使用方式复杂
- 不同身份不同使用方式
- 多个用户可以协作
- 与服务器大量交互,或者使用websocket
- 视图数据从多个来源获取
- 共享组件状态
- 组件之间可以改变状态
Redux相比于的React特点是多交互,多数据源.根据文章,得出一句话:Redux应用具有唯一的Store,一个State对应一个View,View导致了State的变化,改变State的唯一方法是Action对象,store.dispatch()是View 发出 Action 的唯一方法.
- 生成Store的方法:import {createStore} from 'redux'; const store = createStore(fn);fn返回新生成的对象,如果createStore再给一个参数,那么第二个参数将会变成整个应用的状态初始值,并且会覆盖Reducer方法的默认初始值
- View发出Action的方法:store.dispatch();
- 调用Reducer的方法:const store = createStore(reducer);reducer的两个参数分别是state和anction
- 由于Reducer是纯函数,所以State不能任意改变,但是可以定义多个reducer从而得到多个不同的State,而且与View对应的State总是不变
- 监听State的方法:store.subscribe(listener); 相应解除监听的方法:unsubscribe();
Reducer方法负责生成State,由于整个应用只有一个State对象,所以可以使用Reducer方法拆分的形式,化整为零,然后各个方法处理完之后,再使用combineReducers方法将这些Reducer整合起来,有两种的书写形式:
1.非自定义名称
import {combineReducers} from 'redux';
const chat = combineReducers({
chat1,
chat2
})
2.自定义名称
import {combineReducers} from 'redux';
const chat = combineReducers({
a:A,
b:B
})
如果项目中使用的Reducer非常多,那么完全可以放入一个文件中,使用类似于以下代码的方式统一引入:
import {combineReducers} from 'redux';
import * as reducers from './path';
const reducer = combineReducers(reducers);
React + Redux依照作用分文件的形式:“actions”、“constants”、“reducers”、“containers” 以及 “components”
中间件的使用可以方便的添加流程功能,其实现主要在发出Action到Reducer之间,即重写store.dispatch()方法,以下代码是调用方式:
import {applyMiddleware,createStore} from 'redux';
import createLogger from 'redux-logger';//借用redux-logger组件
const logger = createLogger();
const store = createStore(
reducer,
//假设这里存在参数,那么就是上次所说的全局初始化状态initial_state
applyMiddleware(logger) //需要注意的是,中间件参数是有次序要求的,一般logger是放在最后
);
异步操作出现出现的action也会相应的增多至三种,发送/成功/失败,同时必须重新对action的写法进行调整,也就是添加相应的状态和返回参数,如:{type:'fetch',status:'error',error:'err'}.除了action,state也是需要进行改写的,常用的是isFetching(数据抓取判断)和didInvalidate(数据是否过时).
在异步操作时,第一个action是同步触发的,那么第二个action只有通过异步的形式了,利用动作生成器Action Creator,将第一个动作执行完后的结果进行转换,转换为json格式,然后自动再次发出一个action.store.dispatch()的参数仅能够是对象的形式,因此不可以使用函数,可以通过redux-thunk中间件来实现参数使用函数,利用上面所说的applyMiddleware(thunk)的方式,前提肯定是需要import插件的.这是通过写Action Creator返回函数的方式,借助redux-thunk中间件改造dispatch实现异步方案;还可以通过redux-promise中间件改造dispatch,这时Action Creator返回的参数使用Promise对象,还有一种写法将Action对象的payload属性写成Promise对象.
React-Redux将所有的组件分为两大类:UI组件和容器组件,二者区别很明显,如果二者同时处于一个组件中的话,是容器组件包含UI组件.
- UI组件无状态,所有的数据都由this.props提供,不使用Redux的API
- 容器组件带有内部状态,负责管理数据
连接UI组件和容器组件的桥梁是connect()方法:
import {connect} from 'react-redux';
const VisibleTodoList = connect(
mapStateToProps,//此函数返回一个对象,第一个参数为state,第二个参数代表容器组件的props对象
mapDispatchToProps //定义用户操作,可以是函数,也可以是对象,如果是函数,那么会得到dispatch和ownProps两个参数
)(TodoList);//connect的第一个参数是输入逻辑,它将state映射到props,第二个参数是输出逻辑,用户对UI的操作映射成Action
我在理解mapStateToProps和mapDispatchToProps时,借助这篇详细的文档所理解通的:http://www.imooc.com/qadetail/197244?lastmedia=1
在connect方法生成容器组件后,使用React-Redux的Provider组件获取state,工作原理是React组件的context属性,使用方法如下:
import { Provider } from 'react-redux'
import { createStore } from 'redux'
import reducer from './reducers'
import App from './components/App'
let store = createStore(todoApp);
render(
<Provider store={store}>
<App />
</Provider>,
document.getElementById('root')
)
Redux的梳理的更多相关文章
- 前端(十一):props、state及redux关系梳理
所谓状态机,是一种抽象的数据模型,是“事物发展的趋势”,其原理是事件驱动.广泛地讲,世界万物都是状态机. 一.状态机是一种抽象的数据模型 在react中,props和state都可以用来传递数据.这里 ...
- react+redux官方实例TODO从最简单的入门(1)-- 前言
刚进公司的时候,一点react不会,有一个需求要改,重构页面!!!完全懵逼,一点不知道怎么办!然后就去官方文档,花了一周时间,就纯react实现了页面重构,总体来说,react还是比较简单的,由于当初 ...
- Redux你的Angular 2应用--ngRx使用体验
Angular2和Rx的相关知识可以看我的Angular 2.0 从0到1系列第一节:Angular 2.0 从0到1 (一)第二节:Angular 2.0 从0到1 (二)第三节:Angular 2 ...
- redux入门指南
前言:大概一个月没有写博客了,这两天正好是周末,就写点东西来梳理下之前几个月的所写与所得; 大概两个月前,学习了一下 redux ,还是一点难度的,花了我一天的时间来搞明白他, 但是都没怎么记录,今天 ...
- Redux 介绍
本文主要是对 Redux 官方文档 的梳理以及自身对 Redux 的理解. 单页面应用的痛点 对于复杂的单页面应用,状态(state)管理非常重要.state 可能包括:服务端的响应数据.本地对响应数 ...
- redux源码图解:createStore 和 applyMiddleware
在研究 redux-saga时,发现自己对 redux middleware 不是太了解,因此,便决定先深入解读一下 redux 源码.跟大多数人一样,发现 redux源码 真的很精简,目录结构如下: ...
- redux源码学习笔记 - applyMiddleware
在创建store时,createStore(reducer, preloadedState, enhancer),除了reducer函数,初始状态,还可以传入enhancer.这个enhancer在c ...
- [React] 11 - Redux: redux
Ref: Redux中文文档 Ref: React 讀書會 - B團 - Level 19 Redux 深入淺出 Ref: React+Redux 分享會 Ruan Yifeng, Redux 架构: ...
- Redux 入门教程(一):基本用法
转自http://www.ruanyifeng.com/blog/2016/09/redux_tutorial_part_one_basic_usages.html(仅供个人学习使用) 首先明确一点, ...
随机推荐
- Cortex-M3的一些概念
[工作模式] 线程模式(Thread mode):处理器复位或异常退出时为此模式.此模式下的代码可以是特权代码也可以是用户代码,通过CONTROL[0]控制.处理模式(Handler mode):出现 ...
- 百度前端代码规范:HTML
HTML 1.代码风格 1.1缩进与换行 [强制] 使用 4 个空格做为一个缩进层级,不允许使用 2 个空格 或 tab 字符. <style> ul { padding:; } < ...
- 公共表达式消除(UVa 12219)
紫书354页的题,将表达式树进行公共表达式消除,化为等价的图.因为需要判断某一个是否出现过,所以需要快速比较,采用哈希表的形式,将a~b与1~27一一对应,不采用0,因为0与0000是相同的,对于每一 ...
- vi常用命令及快捷键
vi常用快捷键 1)移动光标 h :光标左移一个字符j :光标上移一个字符k :光标下移一个字符l :光标右移一个字符 0 :光标移至行首$ :光标移至行尾 H :光标移至屏幕首行M :光标移至屏幕中 ...
- JSON的一些小结
一.js中 1.json字符串转json对象 var json = $.parseJSON(" {'1':'hello'},{'2':'word'} "); for(var i i ...
- Eclipse+PyDev 安装和配置
Eclipse+PyDev 安装和配置 2012-03-17 23:23:23 | 17465次阅读 | 评论:0 条 | Python开发有很多工具,其中Eclipse+Pydev 是最常见的一种 ...
- nodejs教程 安装express及配置app.js文件的详细步骤
来自:http://www.jb51.net/article/36710.htm express.js是nodejs的一个MVC开发框架,并且支持jade等多种模板.下面简单来说说express的 ...
- 一次Windows 安装问题
在 thinpad x250上安装 windows 10时,提示"安装程序无法创建新的系统分区,也无法定位现有系统分区". x250 的主板上自带一个16G的闪存且标识为 主分区, ...
- jenkins构建触发器详解-不登录触发远程构建详解
利用jenkins的远程构建功能,我们可以使用任何脚本,甚至定制一个Web页来控制Job的执行,但是远程构建你如果直接使用的话,老是需要登录才能执行,如何避免登录?稍微折腾了一下,调通了. 1.首先去 ...
- Laravel 5 中使用 Laravel Excel 实现 Excel/CSV 文件导入导出功能
1.简介 Laravel Excel 在 Laravel 5 中集成 PHPOffice 套件中的 PHPExcel,从而方便我们以优雅的.富有表现力的代码实现Excel/CSV文件的导入和导出. 该 ...