一、安装相关包

  

npm install redux react-redux --save

  

二、根据具体情形创建模块文件

  Store.js、Reducer.js、Actions.js

  Store.js的作用在于引出store,方便在使用的时候引入。

  Reducer.js的作用在于定义reducer,最好用combineReducers拆分reducer。

  Actions.js用于定义ActionCreator,方便在dispatch action的时候根据不同变量生成不同action。

三、使用Provider组件以便于所有组件都能直接使用store

  在使用根组件(通常是入口文件index.js)处引入Provider组件。

  在index.js中引入store,

  在ReactDOM.render()方法的第一个参数处使用Provider包裹根组件,

  然后给Provider组件的store属性赋值为之前引入的store。

  

import React from 'react';
import ReactDOM from 'react-dom';
import './index.css';
import App from './App';
import registerServiceWorker from './registerServiceWorker';
import { Provider } from 'react-redux';
import store from './Store'; ReactDOM.render(<Provider store={store}>
<App />
</Provider>, document.getElementById('root'));
registerServiceWorker();

  

四、编写子组件

  先写UI Component,即通常所写的普通组件;

  然后定义Container Component,使用connect方法(从react-redux包中引入)即可将UI Component转化为Container Component。

  注意要传递mapStateToProps、mapDispatchToProps两个参数。

最后导出组件以便于使用的时候引入。

  

import React from 'react';
import { connect } from 'react-redux';
import { toggleItemAction, removeItemAction } from './Reducer'; class Display extends React.Component {
componentWillMount(){
this.toggleCompleted = this.props.toggleCompleted;
this.removeItem = this.props.removeItem;
console.log(this.props);
}
render(){
return <div>
<ul>
{
this.props.items.map(item => {
let tmp = null;
if(item.completed){
tmp = <del>{item.value}</del>
}
else {
tmp = item.value;
}
if(tmp === null || tmp ===''){
return null;
}
return <li key={item.id}>
{tmp}
<button id={'toggle' + item.id} onClick={this.toggleCompleted}>Toggle</button>
<button id={'remove' + item.id} onClick={this.removeItem}>Remove</button>
</li>
})
}
</ul>
</div>
}
} const mapStateToProps = (state) => {
return {
items: state.items
};
}; const mapDispatchToProps = (dispatch) => {
return {
toggleCompleted(e){
let id = e.target.id.substring(6);
dispatch(toggleItemAction(id));
},
removeItem(e){
let id = e.target.id.substring(6);
dispatch(removeItemAction(id));
}
};
}; const DisplayContainer = connect(mapStateToProps, mapDispatchToProps)(Display); export default DisplayContainer;

  

五、注意点

  1.mapStateToProps参数其实是一个函数,默认带有一个参数为state,作用是将state中的值映射到我们定义的组件的props属性中。

   一下定义一个mapStateToProps:

    

const mapStateToProps = (state) => {
return {
items: state.items
};
};

  这样的话,在组件中就可以通过this.props.items获取到state.items。

  mapStateToProps函数所返回的对象可以认为是组件props属性的一个子集。

  2.mapDispatchToProps参数是一个对象或者函数,我习惯于写成一个函数,函数具有一个默认属性即为dispatch,相当于store.dispatch(),mapDispatchToProps函数会返回一          个对象。对象中的所有方法都会传递给组件的props属性。也可以认为它所返回的对象是组件props属性的一个子集。

const mapDispatchToProps = (dispatch) => {
return {
toggleCompleted(e){
let id = e.target.id.substring(6);
dispatch(toggleItemAction(id));
},
removeItem(e){
let id = e.target.id.substring(6);
dispatch(removeItemAction(id));
}
};
};

  以上代码定义了一个mapDispatchToProps函数,这样,在组件内部可以通过this.props[propertyName]访问到toggleCompleted函数或者removeItem函数。

  3.如何在mapDispatchToProps函数定义的一系列函数中获取组件内部数据?

  解决方法有两种:

  (1)通过event.target来获取事件发生节点,然后通过DOM属性获取组件内部的数据。注意点2中的代码即是例子。

  (2)在组件内部定义事件处理函数,不直接利用this.props[propertyName]来处理组件事件。组件内部自定义事件处理函数可以通过this等获取到组件内部数据,然后在组件自定义事件处理函数内部调用this.props[propertyName],传递参数即可。

  4.是否需要使用react-redux

  react-redux是redux的作者为了方便于在React中使用redux而开发出来的。

  react-redux为我们在react项目中使用redux带来了便利,但也提升了学习成本,我们需要学习一些新的API,并且遵循react-redux的开发及组件拆分规范。

  如果你因为单纯的在项目中使用redux需要不断地引入store,不断地写store.[propertyName]而感到厌烦,那么可以尝试使用react-redux。

  如果你认为使用redux十分方便简洁明了,那么可能并不需要使用react-redux。

使用react-redux开发的简单步骤的更多相关文章

  1. 使用redux开发的简单步骤

    一.安装redux包 npm install redux --save 二.根据APP数据结构或者后台请求的数据结构拟定state的大致结构. 可以把state写成一个对象字面量,放在reducer文 ...

  2. React+Redux开发实战项目【美团App】,没你想的那么难

    README.md 前言 开始学习React的时候,在网上找了一些文章,读了官网的一些文档,后来觉得React上手还是蛮简单的, 然后就在网上找了一个React实战的练手项目,个人学完之后觉得这个项目 ...

  3. react+redux开发谷歌插件

    React Developer Tools Redux Dev Tools

  4. react打包开发文件的步骤(上传给线上环境)

    cd进入ReleaseProject目录,然后运行npm start,系统会自动在public目录下面完成打包工作,然后我再把  public文件下压缩位public.rar上传即可:(public文 ...

  5. 实例讲解基于 React+Redux 的前端开发流程

    原文地址:https://segmentfault.com/a/1190000005356568 前言:在当下的前端界,react 和 redux 发展得如火如荼,react 在 github 的 s ...

  6. React+Redux学习笔记:React+Redux简易开发步骤

    前言 React+Redux 分为两部分: UI组件:即React组件,也叫用户自定义UI组件,用于渲染DOM 容器组件:即Redux逻辑,处理数据和业务逻辑,支持所有Redux API,参考之前的文 ...

  7. webpack+react+redux+es6开发模式

    一.预备知识 node, npm, react, redux, es6, webpack 二.学习资源 ECMAScript 6入门 React和Redux的连接react-redux Redux 入 ...

  8. angular开发者吐槽react+redux的复杂:“一个demo证明你的开发效率低下”

    曾经看到一篇文章,写的是jquery开发者吐槽angular的复杂.作为一个angular开发者,我来吐槽一下react+redux的复杂. 例子 为了让大家看得舒服,我用最简单的一个demo来展示r ...

  9. webpack+react+redux+es6开发模式---续

    一.前言 之前介绍了webpack+react+redux+es6开发模式 ,这个项目对于一个独立的功能节点来说是没有问题的.假如伴随着源源不断的需求,前段项目会涌现出更多的功能节点,需要独立部署运行 ...

随机推荐

  1. Go语言备忘录(3):net/http包的使用模式和源码解析

    本文是晚辈对net/http包的一点浅显的理解,文中如有错误的地方请前辈们指出,以免误导! 转摘本文也请注明出处:Go语言备忘录(3):net/http包的使用模式和源码解析,多谢!  目录: 一.h ...

  2. Jmeter进行性能测试时多台负载机的配置方法

    参考:https://blog.csdn.net/russ44/article/details/54729461 Jmeter进行性能测试时多台负载机的配置方法 Jmeter 是java 应用,对于C ...

  3. SQL执行一次INSERT INTO查询,插入多行记录

    那如果我们想插入多行记录呢?可能你会想到多次运行INSERT语句即可,就像下面的php代码示例: INSERT INTO tbl_name (col1,col2) VALUES (,); 那如果我们想 ...

  4. D3基础---简介和数据

    D3.js是一种数据操作类型的javascript库(也可视其为插件):结合HTML,SVG和CSS,D3可以图形化的,生动的展现数据. d3获取:http://d3js.org/ 在代码文件中引入D ...

  5. Linux From Scratch(从零开始构建Linux系统,简称LFS)(三)

    九. 系统配置 1. 安装 LFS-Bootscripts-20150222 软件包包含一套在 LFS 系统启动和关闭时的启动和停止脚本. cd /sources tar -jxf lfs-boots ...

  6. k8s安装部署过程个人总结及参考文章

    以下是本人安装k8s过程 一.单机配置 1. 环境准备 主机名 IP 配置 master1 192.168.1.181 1C 4G 关闭所有节点的seliux以及firewalld sed -i 's ...

  7. struts2 执行流程及工作原理

    在Struts2框架中的处理大概分为以下的步骤  1 用户发送请求: 2 这个请求经过一系列的过滤器(Filter)(这些过滤器中有一个叫做ActionContextCleanUp的可选过滤器,这个过 ...

  8. wamp配置步骤

    对于初做PHP网站的朋友来说,第一步肯定是希望在自己电脑是搭建PHP环境,省去空间和上传的麻烦!但搭建环境也不是件容易的事情,特别是对于新手同学来说!因此在这里跟大家介绍我作为一名新手在使用的方便好用 ...

  9. js设置时间无效的问题

    在发送短信息验证码的时候要用到js设置时间倒序问题:有时候这种常规写法会导致js失效,试了很多方法才找到问题所在,可能是因为js版本过低导致. setTimeout(showT(t-1),5000) ...

  10. ES6的新知识点

    一.变量 原有变量: var的缺点: 1.可以重复声明 2.无法限制修改 3.没有块级作用域 新增变量: let :不能重复声明,变量-可以修改,块级作用域 const:不能重复声明,变量-不可以修改 ...