
Lesson 40 动手实现 React-redux(五):Provider
发布日期:2022-09-10 03:06:57
浏览次数:1
分类:技术文章
本文共 1432 字,大约阅读时间需要 4 分钟。
Lesson 40 动手实现 React-redux(五):Provider
我们要把 context 相关的代码从所有业务组件中清除出去,现在的代码里面还有一个地方是被污染的。那就是 src/index.js
里面的 Index
:
...class Index extends Component { static childContextTypes = { store: PropTypes.object } getChildContext () { return { store } } render () { return () }}...
其实它要用 context 就是因为要把 store
存放到里面,好让子组件 connect
的时候能够取到 store
。我们可以额外构建一个组件来做这种脏活,然后让这个组件成为组件树的根节点,那么它的子组件都可以获取到 context 了。
我们把这个组件叫 Provider
,因为它提供(provide)了 store
:
在 src/react-redux.js
新增代码:
export class Provider extends Component { static propTypes = { store: PropTypes.object, children: PropTypes.any } static childContextTypes = { store: PropTypes.object } getChildContext () { return { store: this.props.store } } render () { return ({ this.props.children}) }}
Provider
做的事情也很简单,它就是一个容器组件,会把嵌套的内容原封不动作为自己的子组件渲染出来。它还会把外界传给它的 props.store
放到 context,这样子组件 connect
的时候都可以获取到。
可以用它来重构我们的 src/index.js
:
...// 头部引入 Providerimport { Provider } from './react-redux'...// 删除 Index 里面所有关于 context 的代码class Index extends Component { render () { return () }}// 把 Provider 作为组件树的根节点ReactDOM.render(, document.getElementById('root'))
这样我们就把所有关于 context 的代码从组件里面删除了。
当前内容版权归 或其关联方所有,如需对内容或内容相关联开源项目进行关注与资助,请点击 .
最初的起点:
上一篇:
下一篇:
转载地址:https://blog.csdn.net/Mr_zzr/article/details/125798943 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!
发表评论
最新留言
表示我来过!
[***.240.166.169]2023年09月16日 08时31分42秒
关于作者

喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
source insight 4.0 代码函数变量符号高亮
2019-03-07
keil watch窗口看模块全局变量
2019-03-07
Ubuntu下创建虚拟调试串口
2019-03-07
VS2012番茄助手安装破解教程
2019-03-07
vs2012 打开解决方案崩溃或者点击项目崩溃
2019-03-07
C#字符串复制
2019-03-07
c# 自定义类数组实例化与初始化
2019-03-07
wireshark tcp抓包
2019-03-07
TCP的Ack和Seq和len的关系
2019-03-07
C#跨线程调用异常处理方法
2019-03-07
扁平数据转树形结构探究
2019-03-07
一个在关系型数据库中进行海量数据检索的调优案例
2019-03-07
java多线程编程之volatile和CAS
2019-03-07
JAVA中金额数据的处理
2019-03-07
规则引擎drools封装
2019-03-07
电商财务结算系统重构实践
2019-03-07
大数据量业务报表实现思考
2019-03-07
跨进程调用实现之消息组件RabbitMq实例
2019-03-07
小谈mysql存储引擎优化
2019-03-07
java疫苗之殇?关于java类加载器的一些思考
2019-03-07