【React.js小书】动手实现 React-redux(五):Provider - 方志
我们要把 context 相关的代码从所有业务组件中清除出去,现在的代码里面还有一个地方是被污染的。那就是 src/index.js
里面的 Index
:
1 |
... |
其实它要用 context 就是因为要把 store
存放到里面,好让子组件 connect
的时候能够取到 store
。我们可以额外构建一个组件来做这种脏活,然后让这个组件成为组件树的根节点,那么它的子组件都可以获取到 context 了。
我们把这个组件叫 Provider
,因为它提供(provide)了 store
:
在 src/react-redux.js
新增代码:
1 |
export class Provider extends Component { |
Provider
做的事情也很简单,它就是一个容器组件,会把嵌套的内容原封不动作为自己的子组件渲染出来。它还会把外界传给它的 props.store
放到 context,这样子组件 connect
的时候都可以获取到。
可以用它来重构我们的 src/index.js
:
1 |
... import { Provider } from './react-redux' |
这样我们就把所有关于 context 的代码从组件里面删除了。
目录
第一个阶段
- Lesson1 - React.js 简介
- Lesson2 - 前端组件化(一):从一个简单的例子讲起
- Lesson3 - 前端组件化(二):优化 DOM 操作
- Lesson4 - 前端组件化(三):抽象出公共组件类
- Lesson5 - React.js 基本环境安装
- Lesson6 - 使用 JSX 描述UI信息
- Lesson7 - 组件的 render 方法
- Lesson8 - 组件的组合、嵌套和组件树
- Lesson9 - 事件监听
- Lesson10 - 组件的 state 和 setState
- Lesson11 - 配置组件的props
- Lesson12 - state vs props
- Lesson13 - 渲染列表数据
- Lesson14 - 实战分析:评论功能(一)
- Lesson15 - 实战分析:评论功能(二)
- Lesson16 - 实战分析:评论功能(三)
第二个阶段
- Lesson17 - 前端应用状态管理 —— 状态提升
- Lesson18 - 挂载阶段的组件生命周期(一)
- Lesson19 - 挂载阶段的组件生命周期(二)
- Lesson20 - 更新阶段的组件生命周期
- Lesson21 - ref 和 React.js 中的 DOM 操作
- Lesson22 - props.children 和容器类组件
- Lesson23 - dangerouslySetHTML 和 style 属性
- Lesson24 - PropTypes 和组件参数验证
- Lesson25 - 实战分析:评论功能(四)
- Lesson26 - 实战分析:评论功能(五)
- Lesson27 - 实战分析:评论功能(六)
第三个阶段
- Lesson28 - 高阶组件(Higher-Order Components)
- Lesson29 - React.js 的 context
- Lesson30 - 动手实现 Redux(一):优雅地修改共享状态
- Lesson31 - 动手实现 Redux(二):抽离 store 和监控数据变化
- Lesson32 - 动手实现 Redux(三):纯函数(Pure Function)简介
- Lesson33 - 动手实现 Redux(四):共享结构的对象提高性能
- Lesson34 - 动手实现 Redux(五):不要问为什么的 reducer
- Lesson35 - 动手实现 Redux(六):Redux 总结
第四个阶段
- Lesson36 - 动手实现 React-redux(一):初始化工程
- Lesson37 - 动手实现 React-redux(二):结合 context 和 store
- Lesson38 - 动手实现 React-redux(三):connect 和 mapStateToProps
- Lesson39 - 动手实现 React-redux(四):mapDispatchToProps
- Lesson40 - 动手实现 React-redux(五):Provider
- Lesson41 - 动手实现 React-redux(六):React-redux 总结
- Lesson42 - 使用真正的 Redux 和 React-redux
- Lesson43 - Smart 组件 vs Dumb 组件
- Lesson44 - 实战分析:评论功能(七)
- Lesson45 - 实战分析:评论功能(八)
- Lesson46 - 实战分析:评论功能(九)
【React.js小书】动手实现 React-redux(五):Provider - 方志的更多相关文章
- React.js 小书 Lesson23 - dangerouslySetHTML 和 style 属性
作者:胡子大哈 原文链接:http://huziketang.com/books/react/lesson23 转载请注明出处,保留原文链接和作者信息. 这一节我们来补充两个之前没有提到的属性,但是在 ...
- React.js 小书介绍
React.js 小书 Github 关于作者 这是一本关于 React.js 的小书. 因为工作中一直在使用 React.js,也一直以来想总结一下自己关于 React.js 的一些知识.经验.于是 ...
- React.js小书总结
(迁移自旧博客2017 08 27) 第一阶段 react的组件相当于MVC里面的View. react.js 将帮助我们将界面分成了各个独立的小块,每一个块就是组件,这些组件之间可以组合.嵌套,就成 ...
- React.js 小书 Lesson17 - 前端应用状态管理 —— 状态提升
作者:胡子大哈 原文链接:http://huziketang.com/books/react/lesson17 转载请注明出处,保留原文链接和作者信息. 上一个评论功能的案例中,可能会有些同学会对一个 ...
- React.js 小书 Lesson5 - React.js 基本环境安装
作者:胡子大哈 原文链接:http://huziketang.com/books/react/lesson5 转载请注明出处,保留原文链接和作者信息. 安装 React.js React.js 单独使 ...
- 很赞的一个教程: React.js 小书
很赞, React.js 小书 http://huziketang.com/books/react/ 推荐阅读入门, 照着来一遍,能会个七七八八, 更多的还需要多写 import Re ...
- React.js 小书 Lesson25 - 实战分析:评论功能(四)
作者:胡子大哈 原文链接:http://huziketang.com/books/react/lesson25 转载请注明出处,保留原文链接和作者信息. (本文未审核) 目前为止,第二阶段知识已经基本 ...
- React.js 小书 Lesson26 - 实战分析:评论功能(五)
作者:胡子大哈 原文链接:http://huziketang.com/books/react/lesson26 转载请注明出处,保留原文链接和作者信息. (本文未审核) 持久化评论 同样地,可以通过类 ...
- React.js 小书 Lesson24 - PropTypes 和组件参数验证
作者:胡子大哈 原文链接:http://huziketang.com/books/react/lesson24 转载请注明出处,保留原文链接和作者信息. 我们来了到了一个非常尴尬的章节,很多初学的朋友 ...
随机推荐
- Python笔记_第四篇_高阶编程_实例化方法、静态方法、类方法和属性方法概念的解析。
1.先叙述静态方法: 我们知道Python调用类的方法的时候都要进行一个实例化的处理.在面向对象中,一把存在静态类,静态方法,动态类.动态方法等乱七八糟的这么一些叫法.其实这些东西看起来抽象,但是很好 ...
- R语言入门 (有其他编程语言基础)
慢慢才意识到概率统计的重要性,当时学的时候只知道很重要,是机器学习基础啥的,但是却没有真正意识到( ╯□╰ ).我现在的理解是,统计学习可以从大数据中挖掘出规律(其实和数据挖掘还是很相关的),在科研工 ...
- 基于基因调控网络(Hopfield network)构建沃丁顿表观遗传景观
基因调控网络的概念在之前已经简要介绍过:https://www.cnblogs.com/pear-linzhu/p/12313951.html 沃丁顿表观遗传景观(The Waddington's e ...
- 吴裕雄--天生自然ShellX学习笔记:Shell 文件包含
和其他语言一样,Shell 也可以包含外部脚本.这样可以很方便的封装一些公用的代码作为一个独立的文件. Shell 文件包含的语法格式如下: . filename # 注意点号(.)和文件名中间有一空 ...
- MyBatis从入门到精通(第9章):Spring集成MyBatis(中)
MyBatis从入门到精通(第9章):Spring集成MyBatis(中) 框架(Framework)是整个或部分系统的可重用设计,表现为一组抽象构件及构件实例间交互的方法.应该将应用自身的设计和具体 ...
- 模板编程里class 与 typename 的区别
大部分情况下可以相互替换,但是某些情况class 无法替代typename,例如 template< class T, class U > std::shared_ptr<T> ...
- 编程基础-servlet1
1.Servelet是什么 sevlet是Server与Applet 的缩写,即服务端小程序.Sun公司提供的开发动态web资源的技术. servelet本质是java类,但遵循Servlet规范,没 ...
- JVM内存结构图表展示
1.理解的JVM内存结构 2.对于垃圾回收问题 垃圾的回收只在堆和永久区(方法区)中,因为对于线程而言,私有存储空间如栈.本地方法区.程序计数器等,会随着方法的加载完成而直接释放空间,因此不需要进行 ...
- uboot对Flash和DDR的分区管理
1.uboot阶段对Flash的分区 (1).所谓分区,就是对Flash进行分块管理. (2).PC机等产品中,因为大家都是在操作系统下使用硬盘的,整个硬盘由操作系统统一管理,操作系统会使用文件系统帮 ...
- python-day2爬虫基础之爬虫基本架构
今天主要学习了爬虫的基本架构,下边做一下总结: 1.首先要有一个爬虫调度端,来启动爬虫.停止爬虫或者是监视爬虫的运行情况,在爬虫程序中有三个模块,首先是URL管理器来对将要爬取的URL以及爬取过的UR ...