redux入门指南
前言:大概一个月没有写博客了,这两天正好是周末,就写点东西来梳理下之前几个月的所写与所得;
两个月前,学习了一下 redux ,还是一点难度的,花了我一天的时间来搞明白他,
但是都没怎么记录,今天这篇博客就是用一个demo来介绍 redux , react-redux , react-thunk 的简单用法;
首先就是下载,使用命令:
npm install --save redux react-redux react-thunk
下好后 npm start 启动;
文件夹列表如下:

redux 的最关键的函数就是 dispatch !
而 dispatch 的本质是什么呢?
dispatch 接受的是一个对象,这个对象至少有一个是键值是用来判断类型的,其余的可以是任意的;
而他(其实也就是 reducer 函数)他本身有一个 state ,用来存储初始值,根据接受到的对象中的类型键值来判断对于当前值的不同操作,
而且他必须返回修改后的 state;
现在我们创建好文件后修改 src/index.js::
import { createStore,applyMiddleware} from 'redux'
import thunk from 'redux-thunk'
import { Provider } from 'react-redux'
import calcul from './redux/reducer';
let store = createStore(calcul,applyMiddleware(thunk));
ReactDOM.render(<Provider store={store}><App /></Provider>, document.getElementById('root'));
上部的代码中除了 reactDOM.render 是修改的,其他都是新添加的;
这里我们是引用了 redux, redux-thunk, react-redux模块和一个 reducer 文件;
讲一下 createStore 的作用,他在官方文档中的释义是这样的:
创建一个 Redux store 来以存放应用中所有的 state。
应用中应有且仅有一个 store。
其实这只是一个声明赋值,而如果你不用中间件(thunk)可以这样写:
let store = createStore(calcul);
一下子简单了很多;
而 Provider 这个html的标签就是将 redux 的值和函数,传递给整个项目;
上面说到了 create那我们先创建 reducer/index.js:
import { combineReducers } from 'redux'
const countReducer = (state = 0, action) => {
switch (action.type) {
case 'INCREMENT': return state + action.data;
case 'DECREMENT': return state - action.data;
default: return state;
}
};
const calcul = combineReducers({
countReducer
});
export default calcul;
combineReducers 是一个语法糖:他的作用就是将多个reducer函数合并成一个对象;
上面的 countReducer 就是一个reducer函数了,就像我上面所说的,action就是接受的那个对象,
而state就是他自带的初始值,通过switch操作,根据 action.type 的值来进行不同的操作,
但是也是最重要的就是必须有返回值;
接下来是修改src/App.js:
import React, { Component } from 'react';
import {connect} from 'react-redux';
import Calculation from './components/calculation';
class App extends Component {
render() {
const {dispatch,countNum} = this.props;
return (
<div className="App">
<Calculation getValue={countNum} dispatch={dispatch}></Calculation>
</div>
);
}
}
function showData(state) {
return {
countNum:state.countReducer
}
}
export default connect(showData)(App);
connect 函数是来自 react-redux 的,他是一个非常重要的函数,
在最下面一行代码中:connect(showData)(App);
第一个接受的是一个对象,在 showData 中, state 就是所有 reducer 的初始值;
通过这个函数将当前的组件与 redux 中的数值挂钩,他返回的是当期组件所需要的 reducer 的值(你也可以对值进行filter),
而第二个接受对象呢,就是当前组件了;
可以看到,我们还引用了一个名为 Calculation 的组件,他接收了来自 redux 的 dispatch , countNum 这两个参数(函数);
在下一个文件是 src/components/calculation.js:
import React, { Component } from 'react';
import {DECREMENT,middleINCRENT} from '../redux/action';
export default class Count extends Component {
constructor(props) {
super(props);
this.state = {
changeVal:1
}
}
input = (e)=>{
this.setState({changeVal: Number(e.target.value)});
};
render() {
let {dispatch,getValue} = this.props;
return <div>
this is calculation
<h1>{getValue}</h1>
<input type="text" onChange={this.input} value={this.state.changeVal} />
<button onClick={() => (dispatch(middleINCRENT(this.state.changeVal)))}>+</button>
<button onClick={() => (dispatch(DECREMENT(this.state.changeVal)))}>-</button>
</div>
}
}
这个文件引用了文件:src/redux/action/index.js里的 DECREMENT , middleINCRENT 两个函数;
其中 middleINCRENT 便是添加了中间件的 action 函数;
这个组件的作用是什么呢:就是根据 input 里的值,来改变 redux 里的 countReducer 的初始值,靠着点击按钮来触发;
dispatch 我先不说,先说下 DECREMENT , middleINCRENT ,而这就不得不提到下面这个文件:
src/redux/action/index.js:
export function INCREMENT(data){
return {
type:'INCREMENT',
data
}
}
export function middleINCRENT(data) {
return (dispatch, getState) => {
const currentValue = getState();
if(currentValue.countReducer >=200){
return false;
}
dispatch(INCREMENT(data));
}
}
export function DECREMENT(data) {
return {
type:'DECREMENT',
data
}
}
现在你们知道中间件的作用了么?他就是在提交值的时候,对值进行统一的判断和修改, 可以在这个地方进行ajax操作;
我们看这个文件里的 INCREMENT 和 DECREMENT 函数,这两个 函数返回的值就是我最开始所说的, dispatch 所接收的值,
可以看到 type 即是判断的类型了,而 data 呢,就是组件 caculation.js 里的 input 的值;
现在看中间件 middleINCRENT 这个函数,他是返回一个函数,而这个函数可以接受到两个参数,一个呢是 dispatch 函数,而另外一个呢是当前的 reducer 函数的值;
通过学习这个组件, redux 的基本流程可以掌握了,当然实际项目中并不会这么简单,但是原理就是这样;
最后我将这个 demo 放在了GitHub: https://github.com/Grewer/reduxDemo
如果帮到了你,还请推荐或者 star;
完;
redux入门指南的更多相关文章
- Web API 入门指南 - 闲话安全
Web API入门指南有些朋友回复问了些安全方面的问题,安全方面可以写的东西实在太多了,这里尽量围绕着Web API的安全性来展开,介绍一些安全的基本概念,常见安全隐患.相关的防御技巧以及Web AP ...
- Vue.js 入门指南之“前传”(含sublime text 3 配置)
题记:关注Vue.js 很久了,但就是没有动手写过一行代码,今天准备入手,却发现自己比菜鸟还菜,于是四方寻找大牛指点,才终于找到了入门的“入门”,就算是“入门指南”的“前传”吧.此文献给跟我一样“白痴 ...
- yii2实战教程之新手入门指南-简单博客管理系统
作者:白狼 出处:http://www.manks.top/document/easy_blog_manage_system.html 本文版权归作者,欢迎转载,但未经作者同意必须保留此段声明,且在文 ...
- 【翻译】Fluent NHibernate介绍和入门指南
英文原文地址:https://github.com/jagregory/fluent-nhibernate/wiki/Getting-started 翻译原文地址:http://www.cnblogs ...
- ASP.NET MVC 5 入门指南汇总
经过前一段时间的翻译和编辑,我们陆续发出12篇ASP.NET MVC 5的入门文章.其中大部分翻译自ASP.NET MVC 5 官方教程,由于本系列文章言简意赅,篇幅适中,从一个web网站示例开始讲解 ...
- 一起学微软Power BI系列-官方文档-入门指南(1)Power BI初步介绍
我们在前一篇文章微软新神器-Power BI,一个简单易用,还用得起的BI产品中,我们初步介绍了Power BI的基本知识.由于Power BI是去年开始微软新发布的一个产品,虽然已经可以企业级应用, ...
- 一起学微软Power BI系列-官方文档-入门指南(2)获取源数据
我们在文章: 一起学微软Power BI系列-官方文档-入门指南(1)Power BI初步介绍中,我们介绍了官方入门文档的第一章.今天继续给大家介绍官方文档中,如何获取数据源的相关内容.虽然是英文,但 ...
- 一起学微软Power BI系列-官方文档-入门指南(3)Power BI建模
我们前2篇文章:一起学微软Power BI系列-官方文档-入门指南(1)Power BI初步介绍 和一起学微软Power BI系列-官方文档-入门指南(2)获取源数据 中,我们介绍了官方入门文档与获取 ...
- 一起学微软Power BI系列-官方文档-入门指南(4)Power BI的可视化
在前面的系列文章中,我们介绍了官方有关获取数据,以及建模的原始文档和基本介绍.今天继续给大家介绍官方文档中,有关可视化的内容.实际上获获取数据和建模更注重业务关系的处理,而可视化则关注对数据的解读.这 ...
随机推荐
- 开源 免费 java CMS - FreeCMS1.9 移动APP管理 执行配置
项目地址:http://www.freeteam.cn/ 移动APP管理 从FreeCMS 1.8開始支持 执行配置 管理会员能够在这里设置移动app的欢迎图片. 从左側管理菜单点击执行配置进入. 选 ...
- spool命令、创建一个表,创建而且copy表,查看别的用户下的表,rowid行地址 索引的时候使用,表的增删改查,删除表,oracle的回收站
1.spool命令 spool "D:\test.txt" spool off SQL> host cls 2.创建一个表 SQL> --条件(1):有创建 ...
- telematics product and company in China
持续更新中. 总的来看后装OBD市场日渐繁荣,可是应用深度不够:前装infotainment受限于产量和商业模式,举步维艰. 车联网作为汽车信息化的起点,会有泡沫,也会在大数据和物联网的浪潮中逐步积淀 ...
- 兔子-ps抠图
介绍2种方法:1.用高速选择工具 2.用铅笔工具 1.高速选择后.ctrl+c复制,新建空白图片,粘贴进去 2.用钢笔工具在图像的边缘定出若二个点,确定完毕之后按crtl+回车键选择.然后复制,新建空 ...
- Asynchronous vs synchronous client applications(MQTT)
来自我的CSDN博客 想查看英文原文的请点击原文网址.在上两篇翻译中,Homejim我给大家分别翻译了同步客户端应用程序和异步客户端应用程序.本人对这两个的区别也有困惑,因此将paho下的这个比较 ...
- 《Spark大数据处理:技术、应用与性能优化》【PDF】 下载
内容简介 <Spark大数据处理:技术.应用与性能优化>根据最新技术版本,系统.全面.详细讲解Spark的各项功能使用.原理机制.技术细节.应用方法.性能优化,以及BDAS生态系统的相关技 ...
- Java中数据类型及其之间的转换(转)
Java中数据类型及其之间的转换 基本的数据类型 基本类型有以下四种:1)int长度数据类型有:byte(8bits).short(16bits).int(32bits).long(64bits).2 ...
- VR\AR 使用 SceneKit
VR\AR 使用 SceneKit http://www.jianshu.com/c/70d63e3941fd
- Java I/O---概述
对于程序设计者来说,创建一个好的输入/输出系统(I/O)系统是一项艰难的任务. 现在大量不同方案已经说明了这一点.挑战似乎来自于要涵盖所有的可能性.不仅存在各种I/O源端和想要与之通信的接收端(文件. ...
- C# 命名空间和程序集
一.命名空间 1.通过使用using关键字引入命名空间,减少代码量 命名空间对相关的类型进行逻辑分组,通过命名空间能快速的定位到相关的类型,例如:在System.IO命名空间下,定义了所有I/O操作的 ...