react学习记录——状态属性生命周期

Posted wyongz

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了react学习记录——状态属性生命周期相关的知识,希望对你有一定的参考价值。

react的状态state

  React 里,只需更新组件的 state,然后根据新的 state 重新渲染用户界面(不要操作 DOM)

class Clock extends React.Component 
  constructor(props) 
    super(props);
    this.state = date: new Date();
  

  componentDidMount() 
    this.timerID = setInterval(
      () => this.tick(),
      1000
    );
  

  componentWillUnmount() 
    clearInterval(this.timerID);
  

  tick() 
    this.setState(
      date: new Date()
    );
  

  render() 
    return (
      <div>
        <h1>Hello, world!</h1>
        <h2>现在是 this.state.date.toLocaleTimeString().</h2>
      </div>
    );
  


ReactDOM.render(
  <Clock />,
  document.getElementById(‘example‘)
);

  1、通过上边的代码可以看出页面中显示的时间是在state中的,但是在设置计时器后,没过一秒重新更新state的值,页面中显示出来的也会每隔一秒变化一次,说明页面中的内容是跟随数据的变化实时变化的,

  2、时间的变化是因为在tick函数中进行了state的改变,而tick函数中改变state的值是在setState中执行的,所以state的值不能直接改变state,要通过setstate来改变

  3、设置计时器和清除计时器是在两个函数中执行的,这两个函数是生命周期的钩子函数

react的属性props

  react中的props属性是从父组件中获取的,也可以设置默认的属性,如果父组件没有传值的时候直接使用默认的属性

  

class HelloMessage extends React.Component 
  render() 
    return (
      <h1>Hello, this.props.name</h1>
    );
  

 
HelloMessage.defaultProps = 
  name: ‘Runoob‘
;
 //此处如果传入name值使用的是给定的值,如果没有传入值的话使用的是Runoob
const element = <HelloMessage/>;
 
ReactDOM.render(
  element,
  document.getElementById(‘example‘)
);

  props属性是不能被修改的,如果使用需要被修改的值要用state来代替props

react的生命周期

 

组件的生命周期可分成三个状态:

 

  • Mounting:已插入真实 DOM
  • Updating:正在被重新渲染
  • Unmounting:已移出真实 DOM

生命周期的方法有:

    • componentWillMount 在渲染前调用,在客户端也在服务端。

    • componentDidMount : 在第一次渲染后调用,只在客户端。之后组件已经生成了对应的DOM结构,可以通过this.getDOMNode()来进行访问。 如果你想和其他javascript框架一起使用,可以在这个方法中调用setTimeout, setInterval或者发送AJAX请求等操作(防止异步操作阻塞UI)。

    • componentWillReceiveProps 在组件接收到一个新的 prop (更新后)时被调用。这个方法在初始化render时不会被调用。

    • shouldComponentUpdate 返回一个布尔值。在组件接收到新的props或者state时被调用。在初始化时或者使用forceUpdate时不被调用。 
      可以在你确认不需要更新组件时使用。

    • componentWillUpdate在组件接收到新的props或者state但还没有render时被调用。在初始化时不会被调用。

    • componentDidUpdate 在组件完成更新后立即调用。在初始化时不会被调用。

    • componentWillUnmount在组件从 DOM 中移除之前立刻被调用。

 

以上是关于react学习记录——状态属性生命周期的主要内容,如果未能解决你的问题,请参考以下文章

React学习笔记-4-什么是生命周期

React生命周期学习整理

react学习笔记之组件生命周期

React 生命周期

React 学习 ---- 生命周期函数

[转] React之Immutable学习记录