TodoList

脚手架Github地址

1. 编写actions.js

2. 分析state

试着拆分成多个reducer

3. 了解store

  1. store.getState()
  2. store.dispatch(action)
  3. store.subscribe(listener)注册监听器
  4. 调用store.subscribe(listener)返回的函数来注销监听器

4. 了解redux数据流生命周期

  1. store.dispatch(action);
  2. store调用传入的reducer。
  3. 根reducer将多个子reducer输出的state合成一个单一的state树。
  4. store保存了根reducer返回的state树。

5. 分析容器组件和展示组件

在这里,我遇到了很多问题。展示组件就没有什么好说的了,主要是容器组件。

搞清楚,数据到底是如何流动的?

下面举例:

  1. React组件上有一个点击事件。
  2. 当点击之后,点击事件对应一个dispatch(actionCreator())。
  3. store会将actionCreator()返回的action以及当前的state传递给reducer。
  4. reducer收到action,然后根据action.type更新state,并且返回新的state。
  5. store保存新的state。
  6. state更新后,组件调用render()方法。

那么问题来了:

由于展示组件,没有数据,那么数据该是如何来的?

回答:数据是从存放在state里的,如何将state里的数据,传递给展示组件呢?使用connect()函数,它接受两个参数,两个参数分别是函数。

function mapStateToProps(state) {
return {
todos: selectTodos(state.main.todos, state.main.visibilityFilter),
visibilityFilter: state.main.visibilityFilter,
};
} function mapDispatchToProps(dispatch) {
return {
onAddClick: text => dispatch(addTodo(text)),
onFilterChange: nextFilter => dispatch(setVisibilityFilter(nextFilter)),
};
} class Main extends Component {
render() {
return (
<AddTodo
onAddClick={this.props.onAddClick}
/>
<VisibleTodoList />
<Footer
onFilterChange={this.props.onFilterChange}
visibilityFilter={this.props.visibilityFilter}
/>
);
}
} Main.propTypes = {
onAddClick: PropTypes.func.isRequired,
onFilterChange: PropTypes.func.isRequired,
visibilityFilter: PropTypes.oneOf([
'SHOW_ALL',
'SHOW_ACTIVE',
'SHOW_COMPLETED',
]);
}; export default connect(mapStateToProps, mapDispatchToProps)(Main);
  • 上面的demo,是将Main作为一个展示组件。
  • mapStateToPropsmapDispatchToProps注入到Main里。
  • 所以在Main组件里,就可以使用注入的方法和属性了。
  • 值得注意的地方,在Main里使用的props都要进行检测,也就是下面的Main.propTypes
  • 除了将注入和组件写在一个js文件里,还可以将它们分开写。
  • 就比如VisibleTodoList和TodoList分别写。然后将2个函数注入到TodoList里去。
  • 对了,初始化的state是写在reducer里的,因为无论如何都会去调reducer。

在做的过程中,我还遇到了一个问题,它在几个地方三番五次的阻挠我。

// 代码里,我是这么获取state的数据的。
state.todos:
state.visibleFilter; // 但是事实上,使用的脚手架里,它对app包了一层路由,它在最外层的reducer里的代码是这样的。
import main from 'containers/Main/reducer'; export default function createReducer(asyncReducers) {
return combineReducers(
main,
routing: routerReducer,
...asyncReducers,
);
} // 所以我本身拿到的state是包含了main和routing这两个对象的。因此我要拿我组件里的state的数据,应该下面这样:
state.main.todos;
state.visibleFilter;

6. 编写展示组件的代码

  1. class类
  2. 每个组件都要对propTypes进行验证
  3. 要export

7. 编写容器组件

  1. 定义mapStateToProps()将当前的state映射到组件的props, 读取state操作。
  2. 定义mapDispatcherToProps(), 分发action操作。
  • 传入dispatch方法。
  • 返回期望注入到展示组件的props中的回调方法。
  • 回调方法里,可以分发action。
  1. 使用connect()方法。

    export default const VisibleTodoList = connect(
    mapStateToProps,
    mapDispatcherToProps,
    )(TodoList);
    // TodoList为要被注入的展示组件

8. 传入store

使用React Redux里的Provider组件,将store注入到Provider组件,它可以让所有容器组件都可以访问到store。

9. 总结

当我遇到问题:

  1. 要沉着冷静。
  2. 要管理好时间。
  3. 别被bug或error搞的不高兴,要高兴,又有煅炼思维的机会了。
  4. 要思考这是为什么?
  5. 要搞清楚问题的本质。
  6. 要探究问题,探究数据的流动。

10. 参考

React中文文档
Github地址

react+redux+generation-modation脚手架搭建一个todolist的更多相关文章

  1. react+redux+generation-modation脚手架添加一个todolist

    当我遇到问题: 要沉着冷静. 要管理好时间. 别被bug或error搞的不高兴,要高兴,又有煅炼思维的机会了. 要思考这是为什么? 要搞清楚问题的本质. 要探究问题,探究数据的流动. TodoList ...

  2. react全家桶从0搭建一个完整的react项目(react-router4、redux、redux-saga)

    react全家桶从0到1(最新) 本文从零开始,逐步讲解如何用react全家桶搭建一个完整的react项目.文中针对react.webpack.babel.react-route.redux.redu ...

  3. 用vue-cli脚手架搭建一个仿网易云音乐的全家桶vue项目

    一,vue-cli环境搭建 1,全局安装webpack npm install webpack -g 2,安装vue脚手架 npm install vue-cli -g 3,新建一个新的project ...

  4. 如何用vue-cli3脚手架搭建一个基于ts的基础脚手架

    目录 准备工作 搭建项目 vue 中 ts 语法 项目代理及 webpack 性能优化 其他 忙里偷闲,整理了一下关于如何借助 vue-cli3 搭建 ts + 装饰器 的脚手架,并如何自定义 web ...

  5. 看完阮一峰的React教程后, 我写了一个TodoList

    看完阮一峰的React教程后,就自己做了这个TodoList,自己慢慢琢磨效率差了点但是作为入门小练习还是不错的. 以下是效果图:我的源码:todolistUI:bootstrap 4 一.组件化 我 ...

  6. 用脚手架搭建一个 vue 项目

    一.需要安装 node 环境 下载地址: https://nodejs.org/en/ 中文网: http://nodejs.cn/ 安装后为方便国内使用,可以把 npm 换成 taobao 的 cn ...

  7. ReactJS React+Redux+Router+antDesign通用高效率开发模板,夜间模式为例

    工作比较忙,一直没有时间总结下最近学习的一些东西,为了方便前端开发,我使用React+Redux+Router+antDesign总结了一个通用的模板,这个技术栈在前端开发者中是非常常见的. 总的来说 ...

  8. 利用VUE-CLI脚手架搭建VUE项目

    前言 在学习完vue基础语法之后,学着利用vue-cli脚手架搭建一个项目,本篇随笔主要记录搭建的过程,供大家一起学习. 具体内容 搭建vue项目的准备工作 1.安装Nodejs.NPM以及VSCod ...

  9. 从0到1用react+antd+redux搭建一个开箱即用的企业级管理后台系列(基础篇)

    背景 ​ 最近因为要做一个新的管理后台项目,新公司大部分是用vue写的,技术栈这块也是想切到react上面来,所以,这次从0到1重新搭建一个react项目架子,需要考虑的东西的很多,包括目录结构.代码 ...

随机推荐

  1. Python 一些 实用的包(持续更新)

    line_profiler:(代码性能分析) 使用方法:链接 codecs:(Python内置的编码库) 数据分析与挖掘领域: 引自博客:这里     因为他有很多这个领域相关的库可以用,而且很好用, ...

  2. EF – 2.EF数据查询基础(上)查询数据的实用编程技巧

    目录 5.4.1 查询符合条件的单条记录 EF使用SingleOrDefault()和Find()两个方法查询符合条件的单条记录. 5.4.2 Entity Framework中的内部数据缓存 DbS ...

  3. 如何修改WP文章字体格式、字号大小、字体颜色

    在使用wordpress编辑文章的时候,很多朋友会像小编一样,发现它并没有像word文档一样有修改字体样式.字体大小.字体颜色.分页符等功能按钮,对我们写文章极为不便,原因是wordpress默认使用 ...

  4. 关于IPMI的几个问题

    https://blog.csdn.net/lanyang123456/article/details/51712878

  5. 得分(UVa1585)

    题目具体描述见:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_prob ...

  6. xpath语法规则

    参考w3cschool教程 XPath 是一门在 XML 文档中查找信息的语言.XPath 可用来在 XML 文档中对元素和属性进行遍历. XPath 是 W3C XSLT 标准的主要元素,并且 XQ ...

  7. [实战]MVC5+EF6+MySql企业网盘实战(10)——新建文件夹

    写在前面 上篇文章更新了编辑了文件名的操作,本片文章将实现新建文件夹的功能. 系列文章 [EF]vs15+ef6+mysql code first方式 [实战]MVC5+EF6+MySql企业网盘实战 ...

  8. ceph笔记(一)

    一.ceph概述本质上是rados:可靠的.自动的.分布式对象存储特性:高效性(大型的网络raid,性能无限接近raid).统一性(支持文件存储.块存储.对象存储).可扩展性数据库的一个弱点:查表ce ...

  9. Linux与其它类Unix内核的比较

    单块结构的内核:由几个逻辑上独立的成分构成,单块结构,大多数据商用Unix变体也是单块结构: 编译并静态连接的传统Unix内核:Linux能自动按需动态地装载和卸载部分内核代码(模块),而传统Unix ...

  10. CF986B Petr and Permutations [逆序对]

    题目传送门 Petr and Permutations 格式难调,题面就不放了. 分析: 胡乱分析+猜测SP性质一波.然后被学长告知:“1~n的排列交换次数与逆序对的奇偶性相同.”然后就愉快地A了. ...