react+redux+generation-modation脚手架搭建一个todolist
- TodoList
- 1. 编写actions.js
- 2. 分析state
- 3. 了解store
- 4. 了解redux数据流生命周期
- 5. 分析容器组件和展示组件
- 6. 编写展示组件的代码
- 7. 编写容器组件
- 8. 传入store
- 9. 总结
- 10. 参考
TodoList
1. 编写actions.js
2. 分析state
试着拆分成多个reducer
3. 了解store
store.getState()store.dispatch(action)store.subscribe(listener)注册监听器调用store.subscribe(listener)返回的函数来注销监听器
4. 了解redux数据流生命周期
store.dispatch(action);- store调用传入的reducer。
- 根reducer将多个子reducer输出的state合成一个单一的state树。
- store保存了根reducer返回的state树。
5. 分析容器组件和展示组件
在这里,我遇到了很多问题。展示组件就没有什么好说的了,主要是容器组件。
搞清楚,数据到底是如何流动的?
下面举例:
- React组件上有一个点击事件。
- 当点击之后,点击事件对应一个dispatch(actionCreator())。
- store会将actionCreator()返回的action以及当前的state传递给reducer。
- reducer收到action,然后根据action.type更新state,并且返回新的state。
- store保存新的state。
- 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作为一个展示组件。
- 将
mapStateToProps和mapDispatchToProps注入到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. 编写展示组件的代码
- class类
- 每个组件都要对propTypes进行验证
- 要export
7. 编写容器组件
- 定义
mapStateToProps()将当前的state映射到组件的props, 读取state操作。 - 定义
mapDispatcherToProps(), 分发action操作。
- 传入dispatch方法。
- 返回期望注入到展示组件的props中的回调方法。
- 回调方法里,可以分发action。
使用connect()方法。
export default const VisibleTodoList = connect(
mapStateToProps,
mapDispatcherToProps,
)(TodoList);
// TodoList为要被注入的展示组件
8. 传入store
使用React Redux里的Provider组件,将store注入到Provider组件,它可以让所有容器组件都可以访问到store。
9. 总结
当我遇到问题:
- 要沉着冷静。
- 要管理好时间。
- 别被bug或error搞的不高兴,要高兴,又有煅炼思维的机会了。
- 要思考这是为什么?
- 要搞清楚问题的本质。
- 要探究问题,探究数据的流动。
10. 参考
react+redux+generation-modation脚手架搭建一个todolist的更多相关文章
- react+redux+generation-modation脚手架添加一个todolist
当我遇到问题: 要沉着冷静. 要管理好时间. 别被bug或error搞的不高兴,要高兴,又有煅炼思维的机会了. 要思考这是为什么? 要搞清楚问题的本质. 要探究问题,探究数据的流动. TodoList ...
- react全家桶从0搭建一个完整的react项目(react-router4、redux、redux-saga)
react全家桶从0到1(最新) 本文从零开始,逐步讲解如何用react全家桶搭建一个完整的react项目.文中针对react.webpack.babel.react-route.redux.redu ...
- 用vue-cli脚手架搭建一个仿网易云音乐的全家桶vue项目
一,vue-cli环境搭建 1,全局安装webpack npm install webpack -g 2,安装vue脚手架 npm install vue-cli -g 3,新建一个新的project ...
- 如何用vue-cli3脚手架搭建一个基于ts的基础脚手架
目录 准备工作 搭建项目 vue 中 ts 语法 项目代理及 webpack 性能优化 其他 忙里偷闲,整理了一下关于如何借助 vue-cli3 搭建 ts + 装饰器 的脚手架,并如何自定义 web ...
- 看完阮一峰的React教程后, 我写了一个TodoList
看完阮一峰的React教程后,就自己做了这个TodoList,自己慢慢琢磨效率差了点但是作为入门小练习还是不错的. 以下是效果图:我的源码:todolistUI:bootstrap 4 一.组件化 我 ...
- 用脚手架搭建一个 vue 项目
一.需要安装 node 环境 下载地址: https://nodejs.org/en/ 中文网: http://nodejs.cn/ 安装后为方便国内使用,可以把 npm 换成 taobao 的 cn ...
- ReactJS React+Redux+Router+antDesign通用高效率开发模板,夜间模式为例
工作比较忙,一直没有时间总结下最近学习的一些东西,为了方便前端开发,我使用React+Redux+Router+antDesign总结了一个通用的模板,这个技术栈在前端开发者中是非常常见的. 总的来说 ...
- 利用VUE-CLI脚手架搭建VUE项目
前言 在学习完vue基础语法之后,学着利用vue-cli脚手架搭建一个项目,本篇随笔主要记录搭建的过程,供大家一起学习. 具体内容 搭建vue项目的准备工作 1.安装Nodejs.NPM以及VSCod ...
- 从0到1用react+antd+redux搭建一个开箱即用的企业级管理后台系列(基础篇)
背景 最近因为要做一个新的管理后台项目,新公司大部分是用vue写的,技术栈这块也是想切到react上面来,所以,这次从0到1重新搭建一个react项目架子,需要考虑的东西的很多,包括目录结构.代码 ...
随机推荐
- BFC(块级格式化上下文)
渲染规则 1.内部的box会在垂直方向,一个接一个的放置 2.box垂直方向的距离由margin决定,属于同一个bfc的两个相邻box的margin会发生重叠 3.每个元素的margin box的左边 ...
- Adminimize 插件:WordPress根据用户角色显示/隐藏某些后台功能
倡萌刚才分享了 WordPress根据用户角色隐藏文章/页面的功能模块(Meta Boxes),如果你还想根据不同用户角色显示或隐藏后台的某些功能,比如 顶部工具条.左边导航菜单.小工具.仪表盘.菜单 ...
- 安迪的第一个字典(UVa10815)
题目具体描述见:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_prob ...
- Three.js基础探寻八——法向材质与材质的纹理贴图
4.法向材质 法向材质可以将材质的颜色设置为其法向量的方向,有时候对于调试很有帮助. 法向材质的设定很简单,甚至不用设置任何参数: new THREE.MeshNormalMaterial() 材质的 ...
- windows下重置mysql的root密码方法介绍(转)
自己在内网操作的,遇到了一些的问题,其中一个是需要重置密码的,所以网上找了两篇文章,都有一些借鉴的地方. 版本mysql5.7.2,linux系统 除了参考文章还有几点说明: service mysq ...
- Python并发编程-线程锁
互斥锁-Lock #多线程中虽然有GIL,但是还是有可能产生数据不安全,故还需加锁 from threading import Lock, Thread #互斥锁 import time def ea ...
- mycat数据库中间件入门
首先从官网上下载mycat. 官网链接 下载对应的mycat即可. 我也是小白一个,就是直接在window上操作了. 自己画的,真low. 推荐一篇文章 https://blog.csdn.net/u ...
- hiho1393二分图多重匹配
题目链接:[http://hihocoder.com/problemset/problem/1393] 题意:中文题意. 题解:二分图的多重匹配.主要是建图然后跑一个最带流,再判断一下就可以了. 建图 ...
- java 线程 wait join sleep yield notify notifyall synchronized
韩梦飞沙 韩亚飞 313134555@qq.com yue31313 han_meng_fei_sha 休息方法 : 在指定时间内 让该线程 暂停, 不会释放 锁标志. 等待方法: 让 该 线 ...
- bzoj 5294: [Bjoi2018]二进制
Description pupil 发现对于一个十进制数,无论怎么将其的数字重新排列,均不影响其是不是333 的倍数.他想研究对于二进 制,是否也有类似的性质.于是他生成了一个长为n 的二进制串,希望 ...