笔记----深入浅出《React和Redux》第三章Redux框架 (使用React-Redux库)

在直接使用React-Redux库之前,需要做一个铺垫

 

三、容器组件(也叫Smart Component)和展示组件(也叫Dumb Component)

1、用处:这个知识点主要建立在上一章基础上,在上一章中Redux和React进行配合,单个组件处理的任务太多,为了“让每个组件专做一件事”,把组件按处理的任务类型进行拆分,分成容器组件和展示组件,以下是他们的分工

 

       展示组件:接受props,并渲染出来

       容器组件:和Store打交道,处理State

 

 

2、容器组件和展示组件是父子级组件关系,容器组件在外层,展示组件在内层

 

           

     

      展示组件就是一个纯函数,根据容器组件传递过来的props进行渲染

 

 3、代码实践  (修改Counter.js文件)

 

  此次把之前的Counter组件,按功能分成两个组件,一个是Couter,作为展示组件,另一个是CounterContainer,作为容器组件

   

   Counter

   

 

  CounterContainer

  

    

  

    在这里CounterContainer(外层的容器组件)负责和Store进行交互,并将从Store中获取到的状态,通过props传递给Counter(内层的展示组件),然后展示组件将拿到的props值进行渲染,然后在结果一层层的提交出来。在总体看来,和之前的效果一样,但是分工更加细致了

 

      另外,React 支持用函数来表示无状态组件,展示组件Couter也可以写成,结果一样生效

  

 

  最后结果: 

      

 

 

 

 

四、组件Context

 1、用处:提供全局的store,不用考虑store文件在哪个位置,而避免react组件引入store带来的麻烦,

          实现方式就是把这个store塞进组件的context属性中,这样子每个组件都能直接访问到store的状态值了

 

    

 2、在根组件中,将store放入context,之后其他所有子组件就可以通过this.context.store访问到context中store,从而避免了多次引入store带来的麻烦

                        

 

3、代码实现

 

书中是按context旧版本使用方式,新版使用方式虽然略有不同,但是整体思路还是差不多

 

  在主入口文件中App.js

  

  说明:为了不是ControlPanel组件工作变得复杂,在此另写一个根组件Provider,并将store引入,作为Provider组件的属性值

 

 

  Provider.js   

    

  关键的步骤来了,这一步是将store塞进context中,方便之后的子孙组件们轻松调用。

  

  注意注意!!!!!

  (i)这里使用到了需要借助一个函数getChildContext(),他会返回一个context对象,我们需要把store放在这里面

  (ii)在这里还需要用childContextTypes指定context的结构类型,如不指定,会产生错误

 

 

 此时如果将指定类型注释了

 

  

     可以看出getChildContext和childContextTypes搭配使用

 

  

 

  ControlPanel.js

   

  这个保持不变

 

 

    Counter.js

  

  

  这个组件作为PropTypes子组件,可以从context拿去store,而不需要像之前一样,在当前组件中引入store文件之后才可以访问子组件

  

 

  注意注意!!!!!

  在需要调用store的组件中,首先在constructor和super中加入参数context,进行初始化

    然后使用contextTypes指定的store结构类型,记住,如果contextTypes没有被定义,context只是一个空对象

 

 为了在控制台看一下效果,我们打印当前组件进行观察

 

 

 对比注释前后的变化

   

   

 

 

   

   

   最后可以通过this.context.store进行访问了

 

 

   总结:旧版本使用需要

       根组件:

                      getChildContext()放入需要共享的数据

                      childContextTypes指定context中数据的数据类型

                 子组件:

                      contextTypes指定需要接受的context中哪一部分的数据类型

 

 

五、react-redux

   之前三和四的“容器/展示组件”以及“访问store方式”,实现“react-redux”库中最主要的两个功能:

  (1)connect:连接容器组件和展示组件;

  (2)Provider:提供了包含store的context

 

  1、使用react-redux之后的代码

 

  Summary.js

  

  因为展示组件不涉及状态,在这里我以函数形式进行书写,可以对比下面的Summary展示组件以类的形式书写

 

  Counter.js

  

   

 

  App.js入口文件

      

 

   其他代码照旧

 

  (1)connect:

 

      connect(mapStateToProps,mapDispatchToProps)(Counter)

       

这个方法接受两个参数mapStateToProps和mapDispatchToProps,执行结果仍然是一个函数,所以之后继续加了一个小括号,其中小括号里放了展示组件,经过这两个执行后产生容器组件

      

mapStateToProps和mapDispatchToProps是两个函数,mapStateToProps负责将Store上状态转化为内层组件的props,mapDispatchToProps负责将动作进行派发

      

 

  (2)Provider

 

react-redux中封装了类似我们之前写的Provider类,但是里面更加严谨,比如不仅要求store是一个object,还要求store是一个包含subscribe,dispatch,getState函数的store

 

 

 

 

 

部分参考

https://reactjs.org/docs/legacy-context.html

 

posted @ 2019-01-08 13:53  clicli  阅读(292)  评论(0编辑  收藏  举报