下载APP
登录
关闭
讲堂
算法训练营
Python 进阶训练营
企业服务
极客商城
客户端下载
兑换中心
渠道合作
推荐作者
当前播放: 14 | Redux(4) : 理解异步Action、Redux中间件
00:00 / 00:00
标清
  • 标清
1.0x
  • 2.0x
  • 1.5x
  • 1.25x
  • 1.0x
  • 0.5x
网页全屏
全屏
00:00
付费课程,可试看

React实战进阶45讲

共46讲 · 45课时·约560分钟
6241
免费
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) : 深入理解S...
13 | Redux(3) : 在React中...
14 | Redux(4) : 理解异步A...
15 | Redux(5) : 如何组织A...
16 | Redux(6) : 理解不可...
17 | React Router(1):路由...
18 | React Router(2):参数...
19 | UI组件库对比和介绍:Ant...
20 | 使用Next.js创建React同...
21 | 使用Jest、Enzyme等工具...
22 | 常用开发调试工具:ESLint...
23 | 前端项目的理想架构:可维...
24 | 拆分复杂度(1):按领域...
25 | 拆分复杂度(2):如何组...
26 | 拆分复杂度(3):如何组...
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实现对...
39 | 集成第三方JS库:以d3.js...
40 | 基于路由实现菜单导航
41 | React中拖放的实现
42 | 性能永远是第一需求:时刻...
43 | 网络性能优化:自动化按需...
44 | 使用Reselect避免重复计算
45 | 下一代React:异步渲染
46 | 使用Chrome DevTool进行...
本节摘要
展开

精选留言(4)

  • 2019-04-03
    loading不应该作为一种状态呀,这一点我很抗拒的,
    我用axios做,调用http请求之前有个钩子函数,里面添加loading状态,,loading状态应该在统一的地方做一个拦截处理,要么就写在组件内部,把loading作为一种单独的action我是比较抗拒的。
  • 2018-12-02
    老师:下面这段代码,mapDispatchToProps函数体中返回的对象里有个key是actions,它实际起什么作用?
    function mapStateToProps(state) {
      return {
        examples: state.examples,
      };
    }

    /* istanbul ignore next */
    function mapDispatchToProps(dispatch) {
      return {
        actions: bindActionCreators({ fetchRedditList }, dispatch),
      };
    }

    export default connect(mapStateToProps, mapDispatchToProps)(RedditListPage);

    之前我看您demo的一段代码,它也是用的connect,但是它是这样返回的,它跟上面的返回方式不太一样,请问这两者有什么区别?:
    function mapStateToProps(state) {
      return {
        count: state.count
      };
    }

    function mapDispatchToProps(dispatch) {
      return bindActionCreators({ plusOne, minusOne }, dispatch);
    }

    const ConnectedCounter = connect(mapStateToProps, mapDispatchToProps)(Counter);
    展开

    作者回复: 这里的 actions 是传给组件的一个属性,可以是任意名字,使用时可以通过 this.props.actiions.xxx() 来引用某个 action,除了这么做,也可以把 xxx 直接传给组件,也就是后面的做法,从而通过 this.props.xxx() 来使用这个 action。所以用 actions 只是为了把多个 action 组织成了一个 属性传给了组件。

  • 2018-09-17
    rekit这个工具是否可以支持选择 redux或者mobx

    作者回复: Mobx 暂不支持,不过3.0 发布后可以很容易添加支持

  • 2018-06-26
    Hi 老师,fetchRedditList的源码在哪里可以看到呢?

    作者回复: https://github.com/supnate/rekit-boilerplate-cra/blob/master/src/features/examples/redux/fetchRedditList.js
    用 Rekit 创建一个项目也可以看到