亚洲最大看欧美片,亚洲图揄拍自拍另类图片,欧美精品v国产精品v呦,日本在线精品视频免费

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

    react生命周期分為幾個階段

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

    react生命周期分為幾個階段

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

    react生命周期分為幾個階段

    生命周期(Life Cycle)的概念應用很廣泛,特別是在經(jīng)濟、環(huán)境、技術(shù)、社會等諸多領域經(jīng)常出現(xiàn),其基本涵義可以通俗地理解為“從搖籃到墳墓”(Cradle-to-Grave)的整個過程

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

    流程

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

    • 創(chuàng)建階段

    • 更新階段

    • 卸載階段

    創(chuàng)建階段

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

    • 構(gòu)造函數(shù)(不要問我為什么用中文,因為英文會被吞掉,太難了)

    • getDerivedStateFromProps

    • render

    • componentDidMount

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

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

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

    getDerivedStateFromProps

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

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

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

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

    render

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

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

    componentDidMount

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

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

    更新階段

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

    • getDerivedStateFromProps

    • shouldComponentUpdate

    • render

    • getSnapshotBeforeUpdate

    • componentDidUpdate

    getDerivedStateFromProps

    該方法介紹同上

    shouldComponentUpdate

    用于告知組件本身基于當前的props和state是否需要重新渲染組件,默認情況返回true

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

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

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

    render

    介紹如上

    getSnapshotBeforeUpdate

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

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

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

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

    componentDidUpdate

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

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

    卸載階段

    componentWillUnmount

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

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

    推薦學習:《react視頻教程》

    贊(0)
    分享到: 更多 (0)
    網(wǎng)站地圖   滬ICP備18035694號-2    滬公網(wǎng)安備31011702889846號