欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

React組件生命周期詳解

 更新時(shí)間:2017年07月03日 10:03:26   作者:juzipchy  
本篇文章主要介紹了React組件生命周期,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧

調(diào)用流程可以參看上圖。

React組件提供了生命周期的鉤子函數(shù)去響應(yīng)組件不同時(shí)刻的狀態(tài),組件的生命周期如下:

  1. 實(shí)例化
  2. 存在期
  3. 銷毀期

實(shí)例化

首次調(diào)用組件時(shí),有以下方法會(huì)被調(diào)用(注意順序,從上到下先后執(zhí)行):

getDefaultProps

這個(gè)方法是用來設(shè)置組件默認(rèn)的props,組件生命周期只會(huì)調(diào)用一次。但是只適合react.createClass直接創(chuàng)建的組件,使用ES6/ES7創(chuàng)建的這個(gè)方法不可使用,ES6/ES7可以使用下面方式:

//es7
class Component {
 static defaultProps = {}
}
//或者也可以在外面定義es6
//Compnent.defaultProps

getInitialState

設(shè)置state初始值,在這個(gè)方法中你已經(jīng)可以訪問到this.props。getDefaultProps只適合React.createClass使用。使用ES6初始化state方法如下:

class Component extends React.Component{
 constructor(){
 this.state = {
  render: true,
 }
 }

componentWillMount

改方法會(huì)在組件首次渲染之前調(diào)用,這個(gè)是在render方法調(diào)用前可修改state的最后一次機(jī)會(huì)。這個(gè)方法很少用到。

render

這個(gè)方法以后大家都應(yīng)該會(huì)很熟悉,JSX通過這里,解析成對(duì)應(yīng)的虛擬DOM,渲染成最終效果。格式大致如下:

class Component extends React.Component{
 render(){
 return (
  <div></div>
 )
 }

componentDidMount

這個(gè)方法在首次真實(shí)的DOM渲染后調(diào)用(僅此一次)當(dāng)我們需要訪問真實(shí)的DOM時(shí),這個(gè)方法就經(jīng)常用到。如何訪問真實(shí)的DOM這里就不想說了。當(dāng)我們需要請(qǐng)求外部接口數(shù)據(jù),一般都在這里處理。

存在期

實(shí)例化后,當(dāng)props或者state發(fā)生變化時(shí),下面方法依次被調(diào)用:

componentWillReceiveProps

每當(dāng)我們通過父組件更新子組件props時(shí)(這個(gè)也是唯一途徑),這個(gè)方法就會(huì)被調(diào)用。

componentWillReceiveProps(nextProps){}

shouldComponentUpdate

字面意思,是否應(yīng)該更新組件,默認(rèn)返回true。當(dāng)返回false時(shí),后期函數(shù)就不會(huì)調(diào)用,組件不會(huì)在次渲染。

shouldComponentUpdate(nextProps,nextState){}

componentWillUpdate

字面意思組件將會(huì)更新,props和state改變后必調(diào)用。

render

跟實(shí)例化時(shí)的render一樣,不多說

componentDidUpdate

這個(gè)方法在更新真實(shí)的DOM成功后調(diào)用,當(dāng)我們需要訪問真實(shí)的DOM時(shí),這個(gè)方法就也經(jīng)常用到。

銷毀期

銷毀階段,只有一個(gè)函數(shù)被調(diào)用:

componentWillUnmount

每當(dāng)組件使用完成,這個(gè)組件就必須從DOM中銷毀,此時(shí)該方法就會(huì)被調(diào)用。當(dāng)我們?cè)诮M件中使用了setInterval,那我們就需要在這個(gè)方法中調(diào)用clearTimeout。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • React中使用react-file-viewer問題

    React中使用react-file-viewer問題

    這篇文章主要介紹了React中使用react-file-viewer問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • React中設(shè)置樣式style方式

    React中設(shè)置樣式style方式

    這篇文章主要介紹了React中設(shè)置樣式style方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-11-11
  • React中jquery引用的實(shí)現(xiàn)方法

    React中jquery引用的實(shí)現(xiàn)方法

    這篇文章主要介紹了React中jquery引用的實(shí)現(xiàn)方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-09-09
  • Webpack 4.x搭建react開發(fā)環(huán)境的方法步驟

    Webpack 4.x搭建react開發(fā)環(huán)境的方法步驟

    這篇文章主要介紹了Webpack 4.x搭建react開發(fā)環(huán)境的方法步驟,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-08-08
  • React系列useSyncExternalStore學(xué)習(xí)詳解

    React系列useSyncExternalStore學(xué)習(xí)詳解

    這篇文章主要為大家介紹了React系列useSyncExternalStore的學(xué)習(xí)及示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-07-07
  • 從零開始搭建webpack+react開發(fā)環(huán)境的詳細(xì)步驟

    從零開始搭建webpack+react開發(fā)環(huán)境的詳細(xì)步驟

    這篇文章主要介紹了從零開始搭建webpack+react開發(fā)環(huán)境的詳細(xì)步驟,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-05-05
  • 在React Native中添加自定義字體的方法詳解

    在React Native中添加自定義字體的方法詳解

    在這篇指南中,我們將探索使用 Google Fonts 在 React Native 應(yīng)用中添加自定義字體的方法,字體是優(yōu)秀用戶體驗(yàn)的基石,使用定制字體可以為你的應(yīng)用程序提供獨(dú)特的身份,需要的朋友可以參考下
    2024-02-02
  • 五分鐘教你了解一下react路由知識(shí)

    五分鐘教你了解一下react路由知識(shí)

    本文主要介紹了react路由知識(shí),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • 解決React報(bào)錯(cuò)React.Children.only expected to receive single React element child

    解決React報(bào)錯(cuò)React.Children.only expected to rece

    這篇文章主要為大家介紹了React報(bào)錯(cuò)React.Children.only expected to receive single React element child分析解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-01-01
  • React 組件間的通信示例

    React 組件間的通信示例

    這篇文章主要介紹了React 組件間的通信示例,主要通信劃分為三種,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-06-06

最新評(píng)論