React 生命周期分為三種狀態
1. 初始化
2.更新
3.銷毀
1、getDefaultProps()
設置默認的props,也可以用dufaultProps設置組件的默認屬性.
2、getInitialState()
在使用es6的class語法時是沒有這個鉤子函數的,可以直接在constructor中定義this.state。此時可以訪問this.props
3、componentWillMount()
組件初始化時只調用,以后組件更新不調用,整個生命周期只調用一次,此時可以修改state。
在渲染前調用,在客戶端也在服務端。
4、 render()
react最重要的步驟,創建虛擬dom,進行diff算法,更新dom樹都在此進行。此時就不能更改state了。
5、componentDidMount()
組件渲染之后調用,只調用一次。
在第一次渲染后調用,只在客戶端。之后組件已經生成了對應的DOM結構,可以通過this.getDOMNode()來進行訪問。
如果你想和其他JavaScript框架一起使用,可以在這個方法中調用setTimeout,setInterval或者發送AJAX請求等操作(防止異步操作阻塞UI)。
6、componentWillReceiveProps(nextProps)
組件初始化時不調用,組件接受新的props時調用。
使用componentWillReceiveProps的時候,不要去向上分發,調用父組件的相關setState方法,否則會成為死循環
在組件接收到一個新的prop (更新后)時被調用。這個方法在初始化render時不會被調用。
7、shouldComponentUpdate(nextProps, nextState)
react性能優化非常重要的一環。組件接受新的state或者props時調用,我們可以設置在此對比前后兩個props和state是否相同,
如果相同則返回false阻止更新,因為相同的屬性狀態一定會生成相同的dom樹,這樣就不需要創造新的dom樹和舊的dom樹進行diff算法對比,
節省大量性能,尤其是在dom結構復雜的時候
返回一個布爾值。在組件接收到新的props或者state時被調用。
在初始化時或者使用forceUpdate時不被調用。
可以在你確認不需要更新組件時使用。
8、componentWillUpdata(nextProps, nextState)
組件初始化時不調用,只有在組件將要更新時才調用,此時可以修改state
9、render()
組件渲染
10、componentDidUpdate()
組件初始化時不調用,組件更新完成后調用,此時可以獲取dom節點。
11、componentWillUnmount()
組件將要卸載時調用,一些事件監聽和定時器需要在此時清除。
只執行一次: constructor、componentWillMount、componentDidMount
執行多次:render 、子組件的componentWillReceiveProps、componentWillUpdate、componentDidUpdate
有條件的執行:componentWillUnmount(頁面離開,組件銷毀時)
不執行的:根組件(ReactDOM.render在DOM上的組件)的componentWillReceiveProps(因為壓根沒有父組件給傳遞props)
componentWillMount組件掛載之前
render組件的渲染方法
componentDidMount組件掛載完成執行
componentWillReceiveProps
觸發條件
1. 當一個組件從父組件接收了參數。
2.如果這個組件第一次被父組件加載的時候不會被執行。
3.這個組件之前已經存在于父組件中,并且接收的數據發生變動這時此方法才會被觸發。
shouldComponentUpdata:是否要更新數據?需要一個返回值true繼續執行下面的生命周期,false就會終止當前組件數
componentWillUpdate:組件將要更新
render:組件的重新渲染
componentDidUpdata:組件完成更新
componentWillUnmount:組件銷毀的時候觸發
感謝各位的閱讀,以上就是“React的生命周期實例分析”的內容了,經過本文的學習后,相信大家對React的生命周期實例分析這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是本站,小編將為大家推送更多相關知識點的文章,歡迎關注!
本文由 貴州做網站公司 整理發布,部分圖文來源于互聯網,如有侵權,請聯系我們刪除,謝謝!
c語言中正確的字符常量是用一對單引號將一個字符括起表示合法的字符常量。例如‘a’。數值包括整型、浮點型。整型可用十進制,八進制,十六進制。八進制前面要加0,后面...
2022年天津專場考試原定于3月19日舉行,受疫情影響確定延期,但目前延期后的考試時間推遲。 符合報名條件的考生,須在規定時間登錄招考資訊網(www.zha...
:喜歡聽,樂意看。指很受歡迎?!巴卣官Y料”喜聞樂見:[ xǐ wén lè jiàn ]詳細解釋1. 【解釋】:喜歡聽,樂意看。指很受歡迎。2. 【示例】:這是...
悟空保是什么保險?據悉悟空保不是保險公司,而是北京悟空??萍加邢薰酒煜碌幕ヂ摼W保險定制平臺,其主營業務主要包括了壽險,車險和場景險,悟空保和多家保險公司都有合作,消費者可以在悟空保里面找到適合自己的保險產品進行投保。悟空保成立于2015年8月,定位互聯網保險定制,平臺創立時就獲得了梅花創投、青山資本、唱吧創始人的天使投資。悟空保是正規的保險公司嗎?悟空保并不是保險公司,而是互聯網保險銷售平臺,屬...
(相關資料圖)最近大家都在討論安安靜靜類似的詞語一年級_安安靜靜類似的詞語有?相關的事情,對此小編也是非常的感應興趣,那么這件事具體又是怎么回事呢?下面就是小編搜索到的關于安安靜靜類似的詞語一年級_安安靜靜類似的詞語有?事件的相關信息,我們一起來看看吧!1、1斯文[sswNWn],[解說]:形容你眼中的儒雅,[出自]:曹青雪琴《紅樓夢》第七回:“人家孩子斯文慣了,一眼就看出你的落魄,笑死我了。2、...
中信銀行網上銀行電子對賬流程客戶在我行辦理相關簽約手續??蛻艨梢酝ㄟ^登陸網銀系統進行中信銀行網上銀行電子對賬。選擇進入相應的功能,并按照提示輸入相應的查詢條件。系統自動返回所需信息,客戶可以選擇相應的方式進行保存查詢結果。對于查詢得到得的對賬信息,客戶可以進行核對,并直接回簽意見。在線打印帶有條形碼與印章得對賬單,并直接將之作為記賬憑證。銀行對賬多久對一次?大多數是一個月對賬一次。銀行對賬指的是企...