成人伊人青草久久综合网_91在线视频免费观看_毛片免费视频网站_亚洲欧美日韩在线中文字幕

react生命周期有哪些_react生命周期 世界觀速訊

來源:互聯(lián)網(wǎng)

1、概述 就像 Android 開發(fā)中的 View 一樣,React Native(RN) 中的組件也有生命周期(Lifecycle)。


【資料圖】

2、所謂生命周期,就是一個對象從開始生成到最后消亡所經(jīng)歷的狀態(tài),理解生命周期,是合理開發(fā)的關(guān)鍵。

3、RN 組件的生命周期整理如下圖: 如圖,可以把組件生命周期大致分為三個階段: 第一階段:是組件第一次繪制階段,如圖中的上面虛線框內(nèi),在這里完成了組件的加載和初始化; 第二階段:是組件在運行和交互階段,如圖中左下角虛線框,這個階段組件可以處理用戶交互,或者接收事件更新界面; 第三階段:是組件卸載消亡的階段,如圖中右下角的虛線框中,這里做一些組件的清理工作。

4、 生命周期回調(diào)函數(shù) 下面來詳細介紹生命周期中的各回調(diào)函數(shù)。

5、 getDefaultProps 在組件創(chuàng)建之前,會先調(diào)用 getDefaultProps(),這是全局調(diào)用一次,嚴格地來說,這不是組件的生命周期的一部分。

6、在組件被創(chuàng)建并加載候,首先調(diào)用 getInitialState(),來初始化組件的狀態(tài)。

7、 componentWillMount 然后,準(zhǔn)備加載組件,會調(diào)用 componentWillMount(),其原型如下: void componentWillMount() 這個函數(shù)調(diào)用時機是在組件創(chuàng)建,并初始化了狀態(tài)之后,在第一次繪制 render() 之前。

8、可以在這里做一些業(yè)務(wù)初始化操作,也可以設(shè)置組件狀態(tài)。

9、這個函數(shù)在整個生命周期中只被調(diào)用一次。

10、 componentDidMount 在組件第一次繪制之后,會調(diào)用 componentDidMount(),通知組件已經(jīng)加載完成。

11、函數(shù)原型如下: void componentDidMount() 這個函數(shù)調(diào)用的時候,其虛擬 DOM 已經(jīng)構(gòu)建完成,你可以在這個函數(shù)開始獲取其中的元素或者子組件了。

12、需要注意的是,RN 框架是先調(diào)用子組件的 componentDidMount(),然后調(diào)用父組件的函數(shù)。

13、從這個函數(shù)開始,就可以和 JS 其他框架交互了,例如設(shè)置計時 setTimeout 或者 setInterval,或者發(fā)起網(wǎng)絡(luò)請求。

14、這個函數(shù)也是只被調(diào)用一次。

15、這個函數(shù)之后,就進入了穩(wěn)定運行狀態(tài),等待事件觸發(fā)。

16、 componentWillReceiveProps 如果組件收到新的屬性(props),就會調(diào)用 componentWillReceiveProps(),其原型如下: void componentWillReceiveProps( object nextProps ) 輸入?yún)?shù) nextProps 是即將被設(shè)置的屬性,舊的屬性還是可以通過 this.props 來獲取。

17、在這個回調(diào)函數(shù)里面,你可以根據(jù)屬性的變化,通過調(diào)用 this.setState() 來更新你的組件狀態(tài),這里調(diào)用更新狀態(tài)是安全的,并不會觸發(fā)額外的 render() 調(diào)用。

18、如下: componentWillReceiveProps: function(nextProps) { this.setState({ likesIncreasing: nextProps.likeCount >this.props.likeCount }); } shouldComponentUpdate 當(dāng)組件接收到新的屬性和狀態(tài)改變的話,都會觸發(fā)調(diào)用 shouldComponentUpdate(...),函數(shù)原型如下: boolean shouldComponentUpdate( object nextProps, object nextState ) 輸入?yún)?shù) nextProps 和上面的 componentWillReceiveProps 函數(shù)一樣,nextState 表示組件即將更新的狀態(tài)值。

19、這個函數(shù)的返回值決定是否需要更新組件,如果 true 表示需要更新,繼續(xù)走后面的更新流程。

20、否者,則不更新,直接進入等待狀態(tài)。

21、 默認情況下,這個函數(shù)永遠返回 true 用來保證數(shù)據(jù)變化的時候 UI 能夠同步更新。

22、在大型項目中,你可以自己重載這個函數(shù),通過檢查變化前后屬性和狀態(tài),來決定 UI 是否需要更新,能有效提高應(yīng)用性能。

23、 componentWillUpdate 如果組件狀態(tài)或者屬性改變,并且上面的 shouldComponentUpdate(...) 返回為 true,就會開始準(zhǔn)更新組件,并調(diào)用 componentWillUpdate(),其函數(shù)原型如下: void componentWillUpdate( object nextProps, object nextState ) 輸入?yún)?shù)與 shouldComponentUpdate 一樣,在這個回調(diào)中,可以做一些在更新界面之前要做的事情。

24、需要特別注意的是,在這個函數(shù)里面,你就不能使用 this.setState 來修改狀態(tài)。

25、這個函數(shù)調(diào)用之后,就會把 nextProps 和 nextState 分別設(shè)置到 this.props和 this.state 中。

26、緊接著這個函數(shù),就會調(diào)用 render() 來更新界面了。

27、 componentDidUpdate 調(diào)用了 render() 更新完成界面之后,會調(diào)用 componentDidUpdate() 來得到通知,其函數(shù)原型如下: void componentDidUpdate( object prevProps, object prevState ) 因為到這里已經(jīng)完成了屬性和狀態(tài)的更新了,此函數(shù)的輸入?yún)?shù)變成了 prevProps 和 prevState。

28、 componentWillUnmount 當(dāng)組件要被從界面上移除的時候,就會調(diào)用 componentWillUnmount(),其函數(shù)原型如下: void componentWillUnmount() 在這個函數(shù)中,可以做一些組件相關(guān)的清理工作,例如取消計時器、網(wǎng)絡(luò)請求等。

29、 總結(jié) 到這里,RN 的組件的完整的生命都介紹完了,在回頭來看一下前面的圖,就比較清晰了,把生命周期的回調(diào)函數(shù)總結(jié)成如下表格: 生命周期 調(diào)用次數(shù) 能否使用 setSate() getDefaultProps 1(全局調(diào)用一次) 否 getInitialState 1 否 componentWillMount 1 是 render >=1 否 componentDidMount 1 是 componentWillReceiveProps >=0 是 shouldComponentUpdate >=0 否 componentWillUpdate >=0 否 componentDidUpdate >=0 否 componentWillUnmount 1 否 以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

本文到此分享完畢,希望對大家有所幫助。

標(biāo)簽:

推薦

財富更多》

動態(tài)更多》

熱點

成人伊人青草久久综合网_91在线视频免费观看_毛片免费视频网站_亚洲欧美日韩在线中文字幕

        在线播放亚洲一区| 亚洲一区二区视频在线观看| 午夜精品久久久久久久99水蜜桃 | 久久久久久日产精品| 一二三区精品视频| 成人蜜臀av电影| 夜夜揉揉日日人人青青一国产精品| 在线不卡一区二区| 亚洲色图制服诱惑 | 日韩福利电影在线| 久久在线免费观看| 欧美在线观看一二区| 国产精品久久久久影院| 国内久久精品视频| 最新中文字幕一区二区三区| 91麻豆精品国产91久久久久久| 亚洲色图20p| 粉嫩高潮美女一区二区三区| 亚洲激情男女视频| 欧美精品一区二区三区久久久 | 亚洲电影第三页| 久久久久国产精品免费免费搜索| 日韩成人精品在线| 亚洲国产精品精华液2区45| 欧美日韩美女一区二区| 亚洲人亚洲人成电影网站色| 精品一区二区日韩| 亚洲欧洲性图库| 精品久久久久一区| 日韩高清欧美激情| 国产精品嫩草99a| 欧美一级欧美三级在线观看| 视频在线观看一区| 国产精品久久久久影视| 欧美不卡视频一区| 久久99精品一区二区三区三区| 国产精品美女久久久久aⅴ国产馆| 91精品国产综合久久久蜜臀粉嫩| 亚洲成年人影院| 国产免费观看久久| 日韩女优av电影在线观看| 日日嗨av一区二区三区四区| 中文乱码免费一区二区| 日韩精品一区二区三区在线播放| 免费人成网站在线观看欧美高清| 亚洲视频免费观看| 国产三级一区二区| 成人av在线资源网站| 欧美视频在线播放| 午夜精品在线视频一区| 国产精品女主播在线观看| 2023国产一二三区日本精品2022| 国产永久精品大片wwwapp| 亚洲1区2区3区视频| 亚洲色图丝袜美腿| 久久精品人人做| 欧美刺激午夜性久久久久久久 | 一区二区三区高清| 亚洲国产精品精华液ab| 久久一区二区三区四区| 国产成人午夜精品5599| 欧美综合视频在线观看| 亚洲成人一区二区在线观看| 国产精品久久久久aaaa樱花| 国产午夜精品一区二区| 成人国产亚洲欧美成人综合网| 欧美丝袜第三区| 日韩精品成人一区二区三区| 亚洲色图欧洲色图婷婷| 国产日韩欧美综合在线| www.亚洲精品| 欧美一级午夜免费电影| 久久99九九99精品| 在线中文字幕不卡| 亚洲精品成a人| 国产香蕉久久精品综合网| 欧美精品一区二区久久婷婷| 国产成人免费网站| 欧美久久久久久久久| 久久国产剧场电影| 日本高清免费不卡视频| 日本午夜精品视频在线观看 | 亚洲成人免费电影| 亚洲综合色网站| 亚洲一区二区三区精品在线| 亚洲欧美日韩小说| 亚洲女人小视频在线观看| 国产精品久久久久四虎| 综合激情网...| 国产精品久99| 国产精品初高中害羞小美女文| 久久蜜臀精品av| 亚洲国产精品ⅴa在线观看| 国产欧美一区二区精品性色超碰| 国产精品私人自拍| 国产欧美一区二区精品秋霞影院| 中文无字幕一区二区三区| 国产欧美日韩综合| 国产精品久久久久久久浪潮网站| 国产午夜精品久久久久久免费视 | 成人午夜电影网站| 精品国产一区二区精华| 91麻豆高清视频| 中文字幕免费观看一区| 中文字幕乱码日本亚洲一区二区| 中文字幕在线不卡一区| 亚洲色图一区二区三区| 亚洲国产一区二区三区青草影视| 亚洲国产精品久久艾草纯爱| 日韩av电影天堂| 欧美天堂亚洲电影院在线播放| 韩国女主播一区| 91精选在线观看| 99re6这里只有精品视频在线观看| 久久久久久久久蜜桃| 久久精品视频一区| 亚洲免费毛片网站| 亚洲国产精品精华液网站| 免费人成黄页网站在线一区二区| 欧美老肥妇做.爰bbww视频| 成人黄动漫网站免费app| 久久久国产一区二区三区四区小说 | 一区二区三区在线视频播放| 亚洲成人中文在线| 久久99精品久久只有精品| 这里是久久伊人| 久久久不卡网国产精品一区| 亚洲卡通动漫在线| 色屁屁一区二区| 丁香网亚洲国际| 中文字幕精品一区二区三区精品| 亚洲欧美电影院| 美美哒免费高清在线观看视频一区二区 | 国产人伦精品一区二区| 日韩理论片中文av| 日本成人中文字幕| 制服丝袜日韩国产| 国产亚洲欧美日韩日本| 亚洲综合久久久久| 在线精品观看国产| www.色综合.com| 亚洲蜜臀av乱码久久精品| 色老汉av一区二区三区| 成人在线视频首页| 国产精品国产馆在线真实露脸| 亚洲亚洲精品在线观看| 国产在线视频一区二区| 国产日韩欧美综合一区| 一区二区成人在线视频| 国产黄色精品网站| 国产精品嫩草99a| 色婷婷综合激情| 94色蜜桃网一区二区三区| 亚洲伦理在线免费看| 欧美性色黄大片| 久久免费电影网| 偷拍日韩校园综合在线| 日韩欧美你懂的| 日韩毛片精品高清免费| 国产一区二区三区| 国产精品美女久久久久av爽李琼| 一本在线高清不卡dvd| 99国产精品久久久久久久久久 | 亚洲美女偷拍久久| 国产另类ts人妖一区二区| 国产精品家庭影院| 欧美日韩中文另类| 欧美激情一区二区三区在线| 日本 国产 欧美色综合| 久久精品一二三| 亚洲国产一区二区在线播放| 不卡欧美aaaaa| 亚洲一区二区视频在线| 日韩欧美另类在线| 亚洲欧美另类在线| 国产成人午夜视频| 亚洲自拍偷拍综合| 欧美videos中文字幕| 亚洲图片欧美一区| 99久久精品国产一区| 亚洲bt欧美bt精品| 久久久久久日产精品| 色噜噜久久综合| 国产日韩一级二级三级| 久久精品国产亚洲高清剧情介绍| 中文在线一区二区| 欧美嫩在线观看| 亚洲精品伦理在线| 91在线观看免费视频| 五月天国产精品| 国产无一区二区| 欧美在线一二三四区| 国产精品久久久久婷婷| 丰满白嫩尤物一区二区| 亚洲444eee在线观看| 久久久久久9999| 欧美色视频一区| 亚洲精品久久久久久国产精华液| av在线不卡电影| 免费xxxx性欧美18vr|