React 实战进阶 45 讲
王沛
eBay 中国研发中心资深技术专家
35691 人已学习
新⼈⾸单¥68
课程目录
已完结/共 46 讲
React 实战进阶 45 讲
登录|注册
留言
9
收藏
沉浸
阅读
分享
手机端
回顶部
当前播放: 12 | Redux(2) : 深入理解Store、Action、Reducer
00:00 / 00:00
高清
  • 高清
1.0x
  • 2.0x
  • 1.5x
  • 1.25x
  • 1.0x
  • 0.75x
  • 0.5x
网页全屏
全屏
00:00
付费课程,可试看
01 | 课程介绍
02 | React出现的历史背景及特性介绍
03 | 以组件方式考虑UI的构建
04 | JSX的本质 : 不是模板引擎,而是语法糖
05 | React组件的生命周期及其使用场景
06 | 理解Virtual DOM及key属性的作用
07 | 组件设计模式 : 高阶组件和函数作为子组件
08 | 理解新的Context API及其使用场景
09 | 使用脚手架工具创建React项目
10 | 打包和部署
11 | Redux(1) : 前端为何需要状态管理库
12 | Redux(2) : 深入理解Store、Action、Reducer
13 | Redux(3) : 在React中使用Redux
14 | Redux(4) : 理解异步Action、Redux中间件
15 | Redux(5) : 如何组织Action和Reducer
16 | Redux(6) : 理解不可变数据(Immutability)
17 | React Router(1):路由不只是页面切换,更是代码组织方式
18 | React Router(2):参数定义,嵌套路由的使用场景
19 | UI组件库对比和介绍:Ant.Design、Material UI、Semantic UI
20 | 使用Next.js创建React同构应用
21 | 使用Jest、Enzyme等工具进行单元测试
22 | 常用开发调试工具:ESLint、Prettier、React DevTool、Redux DevTool
23 | 前端项目的理想架构:可维护、可扩展、可测试、易开发、易建构
24 | 拆分复杂度(1):按领域模型(feature)组织代码,降低耦合度
25 | 拆分复杂度(2):如何组织component、action和reducer
26 | 拆分复杂度(3):如何组织React Router的路由配置
27 | 使用Rekit(1):创建项目,代码生成和重构
28 | 使用Rekit(2):遵循最佳实践,保持代码一致性
29 | 使用React Router管理登录和授权
30 | 实现表单(1):初始数据,提交和跳转
31 | 实现表单(2):错误处理,动态表单元素,内容动态加载
32 | 列表页(1):搜索,数据缓存和分页
33 | 列表页(2):缓存更新,加载状态,错误处理
34 | 页面数据需要来源多个请求的处理
35 | 内容页的加载与缓存
36 | 基于React Router实现分步操作
37 | 常见页面布局的实现
38 | 使用React Portals实现对话框,使用antd对话框
39 | 集成第三方JS库:以d3.js为例
40 | 基于路由实现菜单导航
41 | React中拖放的实现
42 | 性能永远是第一需求:时刻考虑性能问题
43 | 网络性能优化:自动化按需加载
44 | 使用Reselect避免重复计算
45 | 下一代React:异步渲染
46 | 使用Chrome DevTool进行性能调优&结课测试
登录 后留言

全部留言(9)

  • 最新
  • 精选
老玉米
老师,请问一下,为什么subscribe必须放在dispatch的前面,不然就无法监听store的变化?

作者回复: 对,这两个调用都是同步的按顺序执行。subscribe先监听了,才能获得后面dispatch带来的store的变化。

2018-11-22
4
小明
reducer就是如何处理action并修改state的函数
2021-03-08
2
抖抖
在7:34分钟的,bindActionCreator函数,似乎内部函数少了参数,关于this和arguments的来源。导致我些许疑惑。 我查看了Redux源码,里面是应该是带有this和arguments参数的,类似与如下(具体参数类型忽略): function bindActionCreator(actionCreator, dispatch) { return function(this, arguments) { return dispatch(actionCreator.apply(this, arguments)) } }
2020-11-10
1
Chaos浩
把预习的文档都看一遍再来听课,顿时豁然开朗
2020-06-10
1
大反派
哈哈哈,我说这么眼熟,原来是二楼的大佬
2021-09-28
blueBean
请问reducer里的switch函数的每一个匹配项为什么不用加break语句?另外既然所有的reducer会接收到所有的action,那为啥还需要用特定的reducer构建的store调用dispatch呢?
2020-12-24
1
忆民
老师有一个问题,React组件注册store.subscribe,有一个action调用时,所有的注册组件都会接受到消息,如果工程很多,是不是会有性能问题?这种由方法避免吗?
2020-01-08
百惠恬恬
bindActionCreators方法第一个参数按照上面给出的实现原理,第一个参数actionCreators不是应该是Object的类型吗?为什么代码里传递的plusOne这种function类型也是可以的那。不是应该用bindActionCreator这个方法吗?
2019-07-15
2
kid1412z
reducer就是一个自动机吗?
2019-06-20
1
收起评论