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()函数,它接受两个参数,两个参数分别是函数。

  1. function mapStateToProps(state) {
  2. return {
  3. todos: selectTodos(state.main.todos, state.main.visibilityFilter),
  4. visibilityFilter: state.main.visibilityFilter,
  5. };
  6. }
  7. function mapDispatchToProps(dispatch) {
  8. return {
  9. onAddClick: text => dispatch(addTodo(text)),
  10. onFilterChange: nextFilter => dispatch(setVisibilityFilter(nextFilter)),
  11. };
  12. }
  13. class Main extends Component {
  14. render() {
  15. return (
  16. <AddTodo
  17. onAddClick={this.props.onAddClick}
  18. />
  19. <VisibleTodoList />
  20. <Footer
  21. onFilterChange={this.props.onFilterChange}
  22. visibilityFilter={this.props.visibilityFilter}
  23. />
  24. );
  25. }
  26. }
  27. Main.propTypes = {
  28. onAddClick: PropTypes.func.isRequired,
  29. onFilterChange: PropTypes.func.isRequired,
  30. visibilityFilter: PropTypes.oneOf([
  31. 'SHOW_ALL',
  32. 'SHOW_ACTIVE',
  33. 'SHOW_COMPLETED',
  34. ]);
  35. };
  36. export default connect(mapStateToProps, mapDispatchToProps)(Main);
  • 上面的demo,是将Main作为一个展示组件。
  • mapStateToPropsmapDispatchToProps注入到Main里。
  • 所以在Main组件里,就可以使用注入的方法和属性了。
  • 值得注意的地方,在Main里使用的props都要进行检测,也就是下面的Main.propTypes
  • 除了将注入和组件写在一个js文件里,还可以将它们分开写。
  • 就比如VisibleTodoList和TodoList分别写。然后将2个函数注入到TodoList里去。
  • 对了,初始化的state是写在reducer里的,因为无论如何都会去调reducer。

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

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

6. 编写展示组件的代码

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

7. 编写容器组件

  1. 定义mapStateToProps()将当前的state映射到组件的props, 读取state操作。
  2. 定义mapDispatcherToProps(), 分发action操作。
  • 传入dispatch方法。
  • 返回期望注入到展示组件的props中的回调方法。
  • 回调方法里,可以分发action。
  1. 使用connect()方法。
  1. export default const VisibleTodoList = connect(
  2. mapStateToProps,
  3. mapDispatcherToProps,
  4. )(TodoList);
  5. // 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

    TodoList 1. 编写actions.js 2. 分析state 试着拆分成多个reducer 3. 了解store 4. 了解redux数据流生命周期 5. 分析容器组件和展示组件 搞清楚,数 ...

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

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

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

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

  4. 重写官方TodoList,对于初学react+redux的人来说,很有好处

    虽然官网的TodoList的例子写的很详细,但是都是一步到位,就是给你一个action,好家伙,全部都写好了,给你一个reducer,所有功能也是都写好了,但是我们这些小白怎么可能一下就消化那么多,那 ...

  5. Redux系列02:一个炒鸡简单的react+redux例子

    前言 在<Redux系列01:从一个简单例子了解action.store.reducer>里面,我们已经对redux的核心概念做了必要的讲解.接下来,同样是通过一个简单的例子,来讲解如何将 ...

  6. 一个 React & Redux的目录树

    |-----------------------------------------| | | | React & Redux | | | |------------------------- ...

  7. 使用react+redux+react-redux+react-router+axios+scss技术栈从0到1开发一个applist应用

    先看效果图 github地址 github仓库 在线访问 初始化项目 #创建项目 create-react-app applist #如果没有安装create-react-app的话,先安装 npm ...

  8. react用脚手架创建一个react单页面项目,react起手式

    官网地址:https://react.docschina.org/ 确保本地安装了Node.js node的版本大于8.10    npm的版本大于5.6 1.在本地的某个位置创建一个文件夹,执行以下 ...

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

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

随机推荐

  1. git merge 冲突

    当前分支为 master 然后操作时: git merge dev 发现有文件冲突. 当我们倾向于使用dev 分支的代码时,可以使用以下命令: git checkout --theirs src/ma ...

  2. C++ Primer 5 CH2 变量和基本类型

    C++ 是一种静态数据类型语言,它的类型检查发生在编译时.因此,编译器需要知道每一个变量对应的数据类型. 2.1 基本内置类型 算术类型 C++ 标准并没有规定带符号类型应如何表示,但是约定了在表示范 ...

  3. 嵌入式ARM开发环境搭建

    1. 安装,配置,启动FTP服务 安装FTP: sudo apt-get install vsftpd 修改vsftpd的配置文件/etc/vsftpd.conf,将下面两行的'#'去掉#local_ ...

  4. PHP流程管理,堪比小小程序

    这个流程管理是从用户登录界面开始,然后提交申请,页面逐级审核通过.这个做起来其实挺简单,只是在某些逻辑方面需要 好好考虑一下. 登录页面就不再多说了,如果要存session的话,我们可以建一个假的登录 ...

  5. websocket 项目应用

    序言 很早就想用起来websocket,可惜需要后台服务的支持,技术的翻新总会给我带来巨大的冲击,最近后端人员学习了websocket相关后台技术.于是我们开始动起来了. 学习 这位大兄弟的文章  h ...

  6. SQL条件循环语句以及异常知识整理

    create or replace procedure pr_test1 is begin > then dbms_output.put_line('条件成立'); elsif > the ...

  7. 浅谈java类集框架和数据结构(2)

    继续上一篇浅谈java类集框架和数据结构(1)的内容 上一篇博文简介了java类集框架几大常见集合框架,这一篇博文主要分析一些接口特性以及性能优化. 一:List接口 List是最常见的数据结构了,主 ...

  8. 使用register_shutdown_function触发写日志,使用fastcgi_finish_request提高响应速度

    公司内部的市场管理系统,一直是我一个人维护,最近老是有开发埋怨,内网的账号被人改了密码,账号被解绑了...哈的,错在这还不是一个完整的系统,既没有严格的权限也没有做操作日志呀... 权限现在是准备做在 ...

  9. POJ1275出纳员的雇佣【差分约束】

    出纳员的雇佣 Tehran的一家每天24小时营业的超市,需要一批出纳员来满足它的需要.超市经理雇佣你来帮他解决问题:超市在每天的不同时段需要不同数目的出纳员(例如:午夜时只需一小批,而下午则需要很多) ...

  10. 3.XML的格式化显示

    使用CSS/XSLT格式化XML,可以使XML具有更加多彩的显示效果. 3.1 使用CSS格式化显示XML 使用CSS格式化XML只需要在XML中加上: <?xml-stylesheet typ ...