React--组件的生命周期

1.1组件生命周期概述

  • 意义:组件的生命周期有助于理解组件的运作方式,完成更复杂的组件功能、分析组件错误原因等
  • 组件的生命周期:组件从创建--》卸载不用的过程
  • 生命周期的每个阶段总是伴随着一些方法调用,这些方法就是生命周期的钩子函数
  • 钩子函数的作用:为开发人员在不同阶段操作组件提供了时机
  • 只有类组件才有生命周期

1.2生命周期的三个阶段

  • 每个阶段的执行时机
  • 每个阶段钩子函数的执行顺序
  • 每个阶段钩子函数的作用

1.3创建时(挂载阶段) 

  • 执行时机:组件创建时(页面加载)
  • 执行顺序:

 

class App extends React.Component{
  constructor(props){
    super(props)
    console.warn('生命周期钩子函数:constructor')
  }
  state={
    count:0
  }
  componentDidMount(){
    console.warn('生命周期钩子函数:componentDidMount')
  }
  render(){
    console.warn('生命周期钩子函数:render')
    // this.setState({
    //   count:2
    // }) //会造成递归渲染
    return(
      <div>
        <h1>统计豆豆被打的次数:</h1>
        <button>打豆豆</button>
      </div>
    )
  }
}
ReactDOM.render(<App/>,//调用的是父组件

document.getElementById('root'))

递归渲染报错截图:

1.4更新时

  • 执行时机:1.setState()2.foreDate()3.组件接收到新的props
  • 说明:以上三者任意一种变化,组件就会重新渲染
  • 执行顺序:

 

class App extends React.Component{
  constructor(props){
    super(props)
  }
  state={
    count:0
  }

  handleClick=()=>{
    this.setState({
      count:this.state.count+1
    })
  }
 
  render(){
    console.warn('生命周期钩子函数:render')
    // this.setState({
    //   count:2
    // }) //会造成递归渲染
    return(
      <div>
        {/* <h1>统计豆豆被打的次数:{this.state.count}</h1> */}
        <Counter count={this.state.count}></Counter>
        <button onClick={this.handleClick}>打豆豆</button>
      </div>
    )
  }
}

class Counter extends React.Component{
  render(){
    console.warn('子组件---生命周期钩子函数:render')
    return(
      <h1 id='title'>统计豆豆被打次数:{this.props.count}</h1>
    )
  }
  componentDidUpdate(prevProps){
    console.warn('子组件--生命周期函数:componentDidUpdate')
    //获取DOM
  const title = document.getElementById('title')
  console.log(title.innerHTML)
  console.log('上一次的props',prevProps,',当前的props:',this.props)
 
     if(prevProps.count !== this.props.count){
       this.setState({})
     }
  }

  
}
ReactDOM.render(<App/>,//调用的是父组件

document.getElementById('root'))

 1.5卸载时(卸载阶段)

  • 执行时机:组件从页面中消失

class App extends React.Component{
  constructor(props){
    super(props)
  }
  state={
    count:0
  }

  handleClick=()=>{
    this.setState({
      count:this.state.count+1
    })
  }
 
  render(){
    return(
      <div>
       {
        this.state.count>3? <span>啊,豆豆被打死了</span>
        :<Counter count={this.state.count}></Counter>
       }
        
        <button onClick={this.handleClick}>打豆豆</button>
      </div>
    )
  }
}

class Counter extends React.Component{
  componentDidMount(){
    setInterval(()=>{
      console.log('定时器正在进行')
    },500
  )
}
  render(){
    return(
      <div>
        {/* {
          this.props.count>3? <span>啊,豆豆被打死了</span>
          :<h1 id='title'>统计豆豆被打次数:{this.props.count}</h1>
        } */}
        <h1 id='title'>统计豆豆被打次数:{this.props.count}</h1>
      </div>
      
    )
  }
  
componentWillUnmount(){
  console.warn('生命周期函数:componentWillUnmount')
  //清理定时器
 clearInterval()
}
  
}
ReactDOM.render(<App/>,//调用的是父组件

document.getElementById('root'))

 

关于this.timerId可参考文章:http://t.csdn.cn/VYDQ3 

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值