1、生命周期图
2、单个组件
class Demo extends React.Component{//构造器constructor(props){console.log("count--constructor")super(props)this.state={count: 1}}//组件将要挂载componentWillMount(){console.log("count--componentWillMount")}//组件挂载完毕componentDidMount(){console.log("count--componentDidMount")}//组将将要被卸载componentWillUnmount(){console.log("count--componentWillUnmount")}//控制组件更新的阀门shouldComponentUpdate(nextProps, nextState, nextContext) {console.log("count--shouldComponentUpdate")return true}//组件将要被更新componentWillUpdate(nextProps, nextState, nextContext) {console.log("count--componentWillUpdate")}//组件更新完毕componentDidUpdate(prevProps, prevState, snapshot) {console.log("count--componentDidUpdate")}death=()=>{ReactDOM.unmountComponentAtNode(document.getElementById('root'))}add=()=>{this.setState({count:this.state.count+1})}//强制更新force=()=>{this.forceUpdate()}// 调用时机:初始化渲染和更新之后render(){console.log("count--render")const {count} = this.statereturn(<div><h1 >当前求和为:{count}</h1><button onClick={this.add}>点我加1</button><button onClick={this.death}>卸载组件</button><button onClick={this.force}>不更改任何数据中的状态,强制更新一下</button></div>)}}
ReactDOM.render(<Demo/>,document.getElementById('root'))
3、父子组件
class A extends React.Component{state={carName:"奔驰"}changeCarName=()=>{this.setState({carName:"奔驰c63"})}render(){return(<div><div>我是A组件</div><button onClick={this.changeCarName}>换车</button><B carName={this.state.carName}></B></div>)}}//创建子组件class B extends React.Component{//组件将要被接收到新的属性componentWillReceiveProps(nextProps, nextContext) {console.log("B----componentWillReceiveProps",nextProps,nextContext)}shouldComponentUpdate(nextProps, nextState, nextContext) {console.log("B----shouldComponentUpdate")return true}componentWillUpdate(nextProps, nextState, nextContext) {console.log("B----componentWillUpdate")}render(){console.log("B----render")return(<div>我是B组件,接收到的车是:{this.props.carName}</div>)}}ReactDOM.render(<A/>,document.getElementById('root'))