react新的生命周期函数getDerivedStateFromProps

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了react新的生命周期函数getDerivedStateFromProps相关的知识,希望对你有一定的参考价值。

参考技术A

getDerivedStateFromProps 的 作用 是为了让 props 能更新到组件内部 state 中。他会在 render 方法之前调用,并且在初始挂载及后续更新时都会被调用。它应返回一个对象来更新 state ,如果返回 null 则不更新任何内容。但注意在没有内容更新的情况下也一定要返回一个 null 值。不然会报错。

这个生命周期的意思就是从props中获取state,这个生命周期替换了原有的生命周期函数 componentWillReceiveProps , getDerivedStateFromProps ,它
是一个静态函数,也就是说不能通过this来访问class的属性,也不 推荐直接访问属性 。而是通过参数提供的 nextPros 以及 prevState 来进行判断,根据新传入的 props 来映射 state 。
注意: 如果传入的props不影响state,则必须返回一个null,一般尽量写在末尾。

在使用此生命周期时,要注意把传入的 props 值和之前传入的 props 进行比较

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新的生命周期函数getDerivedStateFromProps的主要内容,如果未能解决你的问题,请参考以下文章

React16废弃的生命周期和新的生命周期

react 生命周期执行顺序,render执行条件

React 生命周期函数

react中的生命周期函数

玩转 React- 组件的内部状态和生命周期

react生命周期函数