站長(zhǎng)資訊網(wǎng)
        最全最豐富的資訊網(wǎng)站

        react生命周期分為幾個(gè)階段

        react生命周期分為3個(gè)階段;分別是:1、創(chuàng)建階段,也被稱為初始化階段,表示組件第一次在DOM樹中進(jìn)行渲染的過(guò)程;2、更新階段,也叫存在階段,表示組件被重新渲染的過(guò)程;3、卸載階段,也叫銷毀階段,表示組件從DOM中刪除的過(guò)程。

        react生命周期分為幾個(gè)階段

        本教程操作環(huán)境:Windows10系統(tǒng)、react17.0.1版、Dell G3電腦。

        react生命周期分為幾個(gè)階段

        生命周期(Life Cycle)的概念應(yīng)用很廣泛,特別是在經(jīng)濟(jì)、環(huán)境、技術(shù)、社會(huì)等諸多領(lǐng)域經(jīng)常出現(xiàn),其基本涵義可以通俗地理解為“從搖籃到墳?zāi)埂保–radle-to-Grave)的整個(gè)過(guò)程

        跟Vue一樣,React整個(gè)組件生命周期包括從創(chuàng)建、初始化數(shù)據(jù)、編譯模板、掛載Dom→渲染、更新→渲染、卸載等一系列過(guò)程

        流程

        這里主要講述react16.4之后的生命周期,可以分成三個(gè)階段:

        • 創(chuàng)建階段

        • 更新階段

        • 卸載階段

        創(chuàng)建階段

        創(chuàng)建階段主要分成了以下幾個(gè)生命周期方法:

        • 構(gòu)造函數(shù)(不要問(wèn)我為什么用中文,因?yàn)橛⑽臅?huì)被吞掉,太難了)

        • getDerivedStateFromProps

        • render

        • componentDidMount

        構(gòu)造函數(shù)

        實(shí)例過(guò)程中自動(dòng)調(diào)用的方法,在方法內(nèi)部通過(guò)super關(guān)鍵字獲取來(lái)自父組件的props

        在該方法中,通常的操作為初始化state狀態(tài)或者在this上掛載方法

        getDerivedStateFromProps

        該方法是新增的生命周期方法,是一個(gè)靜態(tài)的方法,因此不能訪問(wèn)到組件的實(shí)例

        執(zhí)行時(shí)機(jī):組件創(chuàng)建和更新階段,不論是props變化還是state變化,也會(huì)調(diào)用

        在每次render方法前調(diào)用,第一個(gè)參數(shù)為即將更新的props,第二個(gè)參數(shù)為上一個(gè)狀態(tài)的state,可以比較props 和 state來(lái)加一些限制條件,防止無(wú)用的state更新

        該方法需要返回一個(gè)新的對(duì)象作為新的state或者返回null表示state狀態(tài)不需要更新

        render

        類組件必須實(shí)現(xiàn)的方法,用于渲染DOM結(jié)構(gòu),可以訪問(wèn)組件state與prop屬性

        注意:不要在 render 里面 setState, 否則會(huì)觸發(fā)死循環(huán)導(dǎo)致內(nèi)存崩潰

        componentDidMount

        組件掛載到真實(shí)DOM節(jié)點(diǎn)后執(zhí)行,其在render方法之后執(zhí)行

        此方法多用于執(zhí)行一些數(shù)據(jù)獲取,事件監(jiān)聽(tīng)等操作

        更新階段

        該階段的函數(shù)主要為如下方法:

        • getDerivedStateFromProps

        • shouldComponentUpdate

        • render

        • getSnapshotBeforeUpdate

        • componentDidUpdate

        getDerivedStateFromProps

        該方法介紹同上

        shouldComponentUpdate

        用于告知組件本身基于當(dāng)前的props和state是否需要重新渲染組件,默認(rèn)情況返回true

        執(zhí)行時(shí)機(jī):到新的props或者state時(shí)都會(huì)調(diào)用,通過(guò)返回true或者false告知組件更新與否

        一般情況,不建議在該周期方法中進(jìn)行深層比較,會(huì)影響效率

        同時(shí)也不能調(diào)用setState,否則會(huì)導(dǎo)致無(wú)限循環(huán)調(diào)用更新

        render

        介紹如上

        getSnapshotBeforeUpdate

        該周期函數(shù)在render后執(zhí)行,執(zhí)行之時(shí)DOM元素還沒(méi)有被更新

        該方法返回的一個(gè)Snapshot值,作為componentDidUpdate第三個(gè)參數(shù)傳入

        getSnapshotBeforeUpdate(prevProps, prevState) {     console.log('#enter getSnapshotBeforeUpdate');     return 'foo'; } componentDidUpdate(prevProps, prevState, snapshot) {     console.log('#enter componentDidUpdate snapshot = ', snapshot); }

        此方法的目的在于獲取組件更新前的一些信息,比如組件的滾動(dòng)位置之類的,在組件更新后可以根據(jù)這些信息恢復(fù)一些UI視覺(jué)上的狀態(tài)

        componentDidUpdate

        執(zhí)行時(shí)機(jī):組件更新結(jié)束后觸發(fā)

        在該方法中,可以根據(jù)前后的props和state的變化做相應(yīng)的操作,如獲取數(shù)據(jù),修改DOM樣式等

        卸載階段

        componentWillUnmount

        此方法用于組件卸載前,清理一些注冊(cè)監(jiān)聽(tīng)事件,或者取消訂閱的網(wǎng)絡(luò)請(qǐng)求等

        一旦一個(gè)組件實(shí)例被卸載,其不會(huì)被再次掛載,而只可能是被重新創(chuàng)建

        推薦學(xué)習(xí):《react視頻教程》

        贊(0)
        分享到: 更多 (0)
        網(wǎng)站地圖   滬ICP備18035694號(hào)-2    滬公網(wǎng)安備31011702889846號(hào)
        主站蜘蛛池模板: 久久亚洲欧美日本精品| 久久精品一区二区国产| 香蕉久久夜色精品升级完成| 亚洲国产成人精品女人久久久 | 青草青草久热精品视频在线网站 | 日韩精品毛片| 亚洲欧美日韩久久精品| 亚洲国产精品成人精品无码区| 精品国产一区二区三区不卡| 国产精品欧美亚洲韩国日本| 国产精品1024在线永久免费| 精品久久久久久无码人妻热 | 亚洲精品无码AV中文字幕电影网站| 99久久免费只有精品国产| 人妻偷人精品成人AV| 精品国精品无码自拍自在线| 四虎国产精品免费久久| 精品午夜福利1000在线观看| 69堂午夜精品视频在线| 日韩精品一区二区三区在线观看| 国产精品天干天干在线综合 | 精品人妻一区二区三区毛片| 777国产盗摄偷窥精品0OOO| 99久久久精品| 国产精品主播一区二区| 欧美亚洲国产精品久久蜜芽| 国产精品国产三级国产专播| 国产精品多p对白交换绿帽| 国产日韩久久久精品影院首页 | 国产精品亚洲精品日韩已方| 99久久精品免费| 国产精品超碰12396| 国产高清一级毛片精品| 国产成人精品一区在线 | 人妻精品久久无码区| 91精品成人免费国产片| 青青草精品视频| 国产精品videossex白浆| 国产精品免费久久久久久久久| 国产精品自在线拍国产手机版 | 久久99久久99小草精品免视看|