摘要:組件生命周期的三個(gè)階段加載階段更新階段卸載階段舊的生命周期加載階段涉及個(gè)鉤子函數(shù)加載的時(shí)候調(diào)用一次,可以初始化設(shè)置默認(rèn)的,也可以用設(shè)置組件的默認(rèn)屬性。
組件生命周期的三個(gè)階段
Mounting(加載階段)
Updating(更新階段)
Unmounting(卸載階段)
舊的生命周期 Mounting(加載階段:涉及6個(gè)鉤子函數(shù))constructor()
加載的時(shí)候調(diào)用一次,可以初始化state
getDefaultProps()
設(shè)置默認(rèn)的props,也可以用dufaultProps設(shè)置組件的默認(rèn)屬性。
getInitialState()
初始化state,可以直接在constructor中定義this.state
componentWillMount()
組件加載時(shí)只調(diào)用,以后組件更新不調(diào)用,整個(gè)生命周期只調(diào)用一次,此時(shí)可以修改state
render()
react最重要的步驟,創(chuàng)建虛擬dom,進(jìn)行diff算法,更新dom樹都在此進(jìn)行
componentDidMount()
組件渲染之后調(diào)用,只調(diào)用一次Updating(更新階段:涉及5個(gè)鉤子函數(shù))
componentWillReceivePorps(nextProps)
組件加載時(shí)不調(diào)用,組件接受新的props時(shí)調(diào)用
shouldComponentUpdate(nextProps, nextState)
組件接收到新的props或者state時(shí)調(diào)用,return true就會(huì)更新dom(使用diff算法更新),return false能阻止更新(不調(diào)用render)
componentWillUpdata(nextProps, nextState)
組件加載時(shí)不調(diào)用,只有在組件將要更新時(shí)才調(diào)用,此時(shí)可以修改state
render()
react最重要的步驟,創(chuàng)建虛擬dom,進(jìn)行diff算法,更新dom樹都在此進(jìn)行
componentDidUpdate()
組件加載時(shí)不調(diào)用,組件更新完成后調(diào)用Unmounting(卸載階段:涉及1個(gè)鉤子函數(shù))
componentWillUnmount()
組件渲染之后調(diào)用,只調(diào)用一次組件的基本寫法
import React, { Component } from "react" export default class OldReactComponent extends Component { constructor(props) { super(props) // getDefaultProps:接收初始props // getInitialState:初始化state } state = { } componentWillMount() { // 組件掛載前觸發(fā) } render() { return (新的生命周期 Mounting(加載階段:涉及4個(gè)鉤子函數(shù))Old React.Component
) } componentDidMount() { // 組件掛載后觸發(fā) } componentWillReceivePorps(nextProps) { // 接收到新的props時(shí)觸發(fā) } shouldComponentUpdate(nextProps, nextState) { // 組件Props或者state改變時(shí)觸發(fā),true:更新,false:不更新 return true } componentWillUpdate(nextProps, nextState) { // 組件更新前觸發(fā) } componentDidUpdate() { // 組件更新后觸發(fā) } componentWillUnmount() { // 組件卸載時(shí)觸發(fā) } }
constructor()
加載的時(shí)候調(diào)用一次,可以初始化state
static getDerivedStateFromProps(props, state)
組件每次被rerender的時(shí)候,包括在組件構(gòu)建之后(虛擬dom之后,實(shí)際dom掛載之前),每次獲取新的props或state之后;每次接收新的props之后都會(huì)返回一個(gè)對(duì)象作為新的state,返回null則說(shuō)明不需要更新state;配合componentDidUpdate,可以覆蓋componentWillReceiveProps的所有用法
render()
react最重要的步驟,創(chuàng)建虛擬dom,進(jìn)行diff算法,更新dom樹都在此進(jìn)行
componentDidMount()
組件渲染之后調(diào)用,只調(diào)用一次Updating(更新階段:涉及5個(gè)鉤子函數(shù))
static getDerivedStateFromProps(props, state)
組件每次被rerender的時(shí)候,包括在組件構(gòu)建之后(虛擬dom之后,實(shí)際dom掛載之前),每次獲取新的props或state之后;每次接收新的props之后都會(huì)返回一個(gè)對(duì)象作為新的state,返回null則說(shuō)明不需要更新state;配合componentDidUpdate,可以覆蓋componentWillReceiveProps的所有用法
shouldComponentUpdate(nextProps, nextState)
組件接收到新的props或者state時(shí)調(diào)用,return true就會(huì)更新dom(使用diff算法更新),return false能阻止更新(不調(diào)用render)
render()
react最重要的步驟,創(chuàng)建虛擬dom,進(jìn)行diff算法,更新dom樹都在此進(jìn)行
getSnapshotBeforeUpdate(prevProps, prevState)
觸發(fā)時(shí)間: update發(fā)生的時(shí)候,在render之后,在組件dom渲染之前;返回一個(gè)值,作為componentDidUpdate的第三個(gè)參數(shù);配合componentDidUpdate, 可以覆蓋componentWillUpdate的所有用法
componentDidUpdate()
組件加載時(shí)不調(diào)用,組件更新完成后調(diào)用Unmounting(卸載階段:涉及1個(gè)鉤子函數(shù))
組件渲染之后調(diào)用,只調(diào)用一次Error Handling(錯(cuò)誤處理)
componentDidCatch(error,info)
任何一處的javascript報(bào)錯(cuò)會(huì)觸發(fā)組件的基本寫法
import React, { Component } from "react" export default class NewReactComponent extends Component { constructor(props) { super(props) // getDefaultProps:接收初始props // getInitialState:初始化state } state = { } static getDerivedStateFromProps(props, state) { // 組件每次被rerender的時(shí)候,包括在組件構(gòu)建之后(虛擬dom之后,實(shí)際dom掛載之前),每次獲取新的props或state之后;;每次接收新的props之后都會(huì)返回一個(gè)對(duì)象作為新的state,返回null則說(shuō)明不需要更新state return state } componentDidCatch(error, info) { // 獲取到j(luò)avascript錯(cuò)誤 } render() { return (總結(jié)New React.Component
) } componentDidMount() { // 掛載后 } shouldComponentUpdate(nextProps, nextState) { // 組件Props或者state改變時(shí)觸發(fā),true:更新,false:不更新 return true } getSnapshotBeforeUpdate(prevProps, prevState) { // 組件更新前觸發(fā) } componentDidUpdate() { // 組件更新后觸發(fā) } componentWillUnmount() { // 組件卸載時(shí)觸發(fā) } }
舊的生命周期
新的生命周期
React16新的生命周期棄用了componentWillMount、componentWillReceivePorps,componentWillUpdate
新增了getDerivedStateFromProps、getSnapshotBeforeUpdate來(lái)代替棄用的三個(gè)鉤子函數(shù)(componentWillMount、componentWillReceivePorps,componentWillUpdate)
React16并沒有刪除這三個(gè)鉤子函數(shù),但是不能和新增的鉤子函數(shù)(getDerivedStateFromProps、getSnapshotBeforeUpdate)混用,React17將會(huì)刪除componentWillMount、componentWillReceivePorps,componentWillUpdate
新增了對(duì)錯(cuò)誤的處理(componentDidCatch)
參考React.Component
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/98192.html
摘要:我們目前的計(jì)劃是為不安全生命周期引入別名,和。從現(xiàn)在開始,只有新的生命周期名稱將起作用。從版本開始,更新以響應(yīng)更改的推薦方法是使用新的靜態(tài)生命周期。 注釋:本文是根據(jù)React的官方博客翻譯而成(文章地址:https://reactjs.org/blog/2018...)。主要講述了React之后的更新方向,以及對(duì)之前生命周期所出現(xiàn)的問(wèn)題的總結(jié),之后的React將逐步棄用一些生命周期和...
摘要:卸載階段組件卸載和銷毀老版生命周期之前的生命周期初始化階段涉及個(gè)鉤子函數(shù)這些方法會(huì)在組件初始化的時(shí)候被調(diào)用,只跟實(shí)例的創(chuàng)建有關(guān)。 前言:React 的版本從 v15 到 v16.3 ,再到v16.4,現(xiàn)在最新的版本是 v16.8了。其中最大的變化可能是React Hooks的加入,而最令人困惑的卻是它的生命周期,新舊生命周期函數(shù)混雜在一起,難免會(huì)讓許多新來(lái)者有很多困惑。所以這一篇我們來(lái)...
摘要:因?yàn)榘姹緦⒄嬲龔U棄這三生命周期到目前為止,的渲染機(jī)制遵循同步渲染首次渲染,更新時(shí)更新時(shí)卸載時(shí)期間每個(gè)周期函數(shù)各司其職,輸入輸出都是可預(yù)測(cè),一路下來(lái)很順暢。通過(guò)進(jìn)一步觀察可以發(fā)現(xiàn),預(yù)廢棄的三個(gè)生命周期函數(shù)都發(fā)生在虛擬的構(gòu)建期間,也就是之前。 showImg(https://segmentfault.com/img/bVbweoj?w=559&h=300); 背景 前段時(shí)間準(zhǔn)備前端招聘事項(xiàng)...
摘要:本文主要介紹之后的生命周期。該方法有兩個(gè)參數(shù)和返回值為對(duì)象不需要返回整體,把需要改變的返回即可。必須有一個(gè)返回值,返回的數(shù)據(jù)類型可以有。此生命周期主要用于優(yōu)化性能。最后,說(shuō)明一點(diǎn)這三個(gè)生命周期在未來(lái)版本中會(huì)被廢棄。 React16.3.0開始,生命周期進(jìn)行了一些變化。本文主要介紹React16.3.0之后的生命周期。 React16.3.0之前生命周期: 16版本之前的react組件的...
摘要:的返回值將作為的參數(shù),如果返回,則不更新,不能返回或以外的值,否則會(huì)警告。在更新之前調(diào)用,此時(shí)已更新返回值作為的第個(gè)參數(shù)一般用于獲取之前的數(shù)據(jù)語(yǔ)法是從的返回值,默認(rèn)是的使用場(chǎng)景一般是獲取組建更新之前的滾動(dòng)條位置。 React16 后的各功能點(diǎn)是多個(gè)版本陸陸續(xù)續(xù)迭代增加的,本篇文章的講解是建立在 16.6.0 版本上本篇文章主旨在介紹 React16 之后版本中新增或修改的地方,所以對(duì)于...
閱讀 5156·2023-04-25 19:30
閱讀 2180·2023-04-25 15:09
閱讀 2631·2021-11-16 11:45
閱讀 2189·2021-11-15 18:07
閱讀 1470·2021-11-11 17:22
閱讀 2129·2021-11-04 16:06
閱讀 3586·2021-10-20 13:47
閱讀 3048·2021-09-22 16:03