内容简介:1.安装并引入prop-types2.父组件中设置getChildContext()
React Context
绝大多数应用程序不需要使用 context.如果你想让你的应用更稳定,别使用context。因为这是一个实验性的API,在未来的React版本中可能会被更改。
一、如何使用
1.安装并引入prop-types
2.父组件中设置getChildContext()
class A extends React.Component { getClildContext () { return { info: 'test' /** some code */ } } }
3.父子组件设置childContextTypes
import PropTypes from 'prop-types'; A.childContextTypes = { info: PropTypes.string }
4.子组件定义contextTypes获取context中获取并定义变量类型
B.contextTypes = { info: PropTypes.string }
5.子组件获取context变量
class B extends React.Component { render () { return <div>{this.context.info}</div> } }
完整demo
import PropTypes from 'prop-types'; import React, { Component } from 'react'; class A extends React.Component { getClildContext () { return { info: 'test' /** some code */ } } render () { return <B /> } } A.childContextTypes = { info: PropTypes.string } class B extends React.Component { render () { return <div>{this.context.info}</div> } } B.contextTypes = { info: PropTypes.string }
二、使用要点
1.如果一个组件中定义了contextTypes,在下面的生命周期会获得额外的参数
constructor(props, context); componentWillReceiveProps(nextProps, nextContext); shouldComponentUpdate(nextProps, nextState, nextContext); componentWillDidUpdate(nextProps, nextState, nextContext); componentDidUpdate(prevProps, PrevState, prevContext);
2.无状态下引用context
import PropTypes from 'prop-types' const C = ({ children }, context) => { return ( <h2>{context.info}</h2> ) } C.contextTypes = { info: PropTypes.string }
3.千万不要更新context,可以通过与state绑定更新context,有风险的如果中间父组件通过shouldComponentUpdate返回false,那么接下来的组件中的context是不会更新得。
class A extends React.PureComponent { constructor () { super(); this.state = { info: 'test' } } getChildContext () { return { info: this.state.info } } }
4.PureComponent检测不到context的改变
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
C#入门经典
[美] Karli Watson、Christian Nagel / 齐立波、黄静 / 清华大学出版社 / 2008-12 / 118.00元
这是一本成就无数C#程序员的经典名著,厚而不“重”,可帮助您轻松掌握C#的各种编程知识,为您的职业生涯打下坚实的基础,《C#入门经典》自第1版出版以来,全球销量已经达数万册,在中国也有近8万册的销量,已经成为广大初级C#程序员首选的入门教程,也是目前国内市场上最畅销的C#专业店销书,曾两次被CSDN、《程序员》等机构和读者评选为“最受读者喜爱的十大技术开发类图书”!第4版面向C#2008和.NET......一起来看看 《C#入门经典》 这本书的介绍吧!