RN學(xué)習(xí)之Component生命周期

我們顯示必然要使用到component,React.Component 是一個(gè)抽象的Class咙鞍,通常繼承該類來構(gòu)建自定義的Component。 Component可以將U分離成獨(dú)立的碎片,有點(diǎn)類似于JavaScript的function苍碟,它接受一個(gè)任意的輸入(props)并返回一個(gè)React element描述屏幕中的內(nèi)容。

生命周期及方法

Component和Android中的activity一樣撮执,也有一定的生命周期微峰,官網(wǎng)對(duì)于其生命周期介紹如下:

Component生命周期

基本分為三個(gè)階段:

1、掛載階段

調(diào)用方法:

constructor()?//構(gòu)造函數(shù)

componentWillMount()//將要被掛載

render()//渲染

componentDidMount()// 完成掛載

2抒钱、更新階段

調(diào)用方法:

componentWillReceiveProps(nextProps)?//作為子空間蜓肆,在props改變時(shí)調(diào)用

shouldComponentUpdate(nextProps,nextState)//是否允許更新颜凯,返回boolean

componentWillUpdate(nextProps,nextState)//將要更新

render()//渲染

componentDidUpdate(prevProps,prevState)//完成更新

3、銷毀階段

調(diào)用方法:

componentWillUnmount()//銷毀

具體實(shí)例

//重新寫一個(gè)index.js,來演示component的生命周期

//component是從react中來的

importReact, {Component} from 'react';

//Text以及View等都是從react-native中來的

import{AppRegistry,Text}from'react-native'

//定義一個(gè)Component仗扬,按照ES6的語(yǔ)法來,就和java語(yǔ)法中定義class一樣症概,繼承component

class AndroidTestComponent extends Component{

????//getDefaultProps() is only supported for classes created using React.createClass. We can use a static property to define defaultProps instead.

// getDefaultProps(){

//? ? console.log("AndroidTestComponent=====getDefaultProps")

// }

// 使用這個(gè)方法進(jìn)行定義props

staticdefaultProps= {

color:'red'

};

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

constructor(props) {

super(props)

this.state= {

name:'ruibaobao'

}

console.log("AndroidTestComponent=====constructor")

}

//compoment將要掛載的函數(shù)

componentWillMount() {

console.log("AndroidTestComponent=====componentWillMount")

}

//render屬性對(duì)應(yīng)的函數(shù)會(huì)返回一段JSX來表示該組件的結(jié)構(gòu)和布局。該部分是一個(gè)組件必不可少的地方早芭,沒有這些內(nèi)容彼城,就無法構(gòu)成一個(gè)組件。

//render方法必須返回單個(gè)根元素

//compoment掛載渲染的函數(shù)

render() {

console.log("AndroidTestComponent=====render")

return(

{

this.setState({name:'wwoairuibaobao'})

}}style={{backgroundColor:'red'}}>這是一個(gè)簡(jiǎn)單的測(cè)試text{this.state.name}

//如何使用props

//forceUpdate 會(huì)強(qiáng)制更新component退个,即使shouldComponentUpdate返回false也會(huì)更新

//{this.forceUpdate()}} style={{backgroundColor:this.props.color}} >這只是一個(gè)簡(jiǎn)單的測(cè)試t{this.state.name}{this.props.color}

);

}

//compoment已經(jīng)掛載的函數(shù)

componentDidMount() {

console.log("AndroidTestComponent=====componentDidMount")

}

//屬性改變時(shí)調(diào)用募壕,在封裝、引用子空間時(shí)會(huì)觸發(fā)子空間的這個(gè)方法

componentWillReceiveProps(nextProps) {

console.log("AndroidTestComponent=====componentWillReceiveProps")

}

//在props 和 state更新之后语盈,根據(jù)返回值判斷是否需要更新? true 需要? false 不需要

shouldComponentUpdate(nextProps, nextState) {

console.log("AndroidTestComponent=====shouldComponentUpdate")

console.log(nextProps)

console.log(nextState)

return true;

}

//component將要更新時(shí)調(diào)用

componentWillUpdate(nextProps, nextState) {

console.log("AndroidTestComponent=====componentWillUpdate")

console.log(nextProps)

console.log(nextState)

}

//component更新后調(diào)用

componentDidUpdate(prevProps, prevState) {

console.log("AndroidTestComponent=====componentDidUpdate")

console.log(prevProps)

console.log(prevState)

}

//component銷毀時(shí)調(diào)用

componentWillUnmount() {

console.log("AndroidTestComponent=====componentWillUnmount")

}

}

//另一種定義props的方法舱馅,如果static defaultProps也定義了,這個(gè)會(huì)覆蓋上面的

// AndroidTestComponent.defaultProps = {

//? ? name:'xiaoerlang'

// }

//進(jìn)行注冊(cè) 'RNProject'為項(xiàng)目名稱 AndroidTestComponent 為啟動(dòng)的component

AppRegistry.registerComponent('RNProject', () => AndroidTestComponent);

打印log

1刀荒、reload

I/ReactNativeJS(24891): AndroidTestComponent=====constructor

I/ReactNativeJS(24891): AndroidTestComponent=====componentWillMount

I/ReactNativeJS(24891): AndroidTestComponent=====render

I/ReactNativeJS(24891): AndroidTestComponent=====componentDidMount

2代嗤、點(diǎn)擊‘這是一個(gè)簡(jiǎn)單的測(cè)試text’

I/ReactNativeJS(24891): AndroidTestComponent=====shouldComponentUpdate

I/ReactNativeJS(24891): { rootTag: 1, color: 'red' }

I/ReactNativeJS(24891): { name: 'wwoairuibaobao' }

I/ReactNativeJS(24891): AndroidTestComponent=====componentWillUpdate

I/ReactNativeJS(24891): { rootTag: 1, color: 'red' }

I/ReactNativeJS(24891): { name: 'wwoairuibaobao' }

I/ReactNativeJS(24891): AndroidTestComponent=====render

I/ReactNativeJS(24891): AndroidTestComponent=====componentDidUpdate

I/ReactNativeJS(24891): { rootTag: 1, color: 'red' }

I/ReactNativeJS(24891): { name: 'ruibaobao' }

如果shouldComponentUpdate返回false即

//在props 和 state更新之后,根據(jù)返回值判斷是否需要更新? true 需要? false 不需要

shouldComponentUpdate(nextProps, nextState) {

console.log("AndroidTestComponent=====shouldComponentUpdate")

console.log(nextProps)

console.log(nextState)

return false;

}

點(diǎn)擊text后log

I/ReactNativeJS(24891): AndroidTestComponent=====componentWillUpdate

I/ReactNativeJS(24891): { rootTag: 1, color: 'red' }

I/ReactNativeJS(24891): { name: 'wwoairuibaobao' }

I/ReactNativeJS(24891): AndroidTestComponent=====render

I/ReactNativeJS(24891): AndroidTestComponent=====componentDidUpdate

I/ReactNativeJS(24891): { rootTag: 1, color: 'red' }

I/ReactNativeJS(24891): { name: 'wwoairuibaobao' }

這個(gè)時(shí)候默認(rèn)是沒有進(jìn)行渲染的照棋,只有調(diào)用forceUpdate才會(huì)渲染资溃。


參考文章

英文官網(wǎng)

CSDN RN入門簡(jiǎn)介

CSDN component生命周期

ps:以上網(wǎng)站部分不是最新的語(yǔ)法。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末烈炭,一起剝皮案震驚了整個(gè)濱河市溶锭,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌符隙,老刑警劉巖趴捅,帶你破解...
    沈念sama閱讀 222,865評(píng)論 6 518
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異霹疫,居然都是意外死亡拱绑,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,296評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門丽蝎,熙熙樓的掌柜王于貴愁眉苦臉地迎上來猎拨,“玉大人,你說我怎么就攤上這事屠阻『焓。” “怎么了?”我有些...
    開封第一講書人閱讀 169,631評(píng)論 0 364
  • 文/不壞的土叔 我叫張陵国觉,是天一觀的道長(zhǎng)吧恃。 經(jīng)常有香客問我,道長(zhǎng)麻诀,這世上最難降的妖魔是什么痕寓? 我笑而不...
    開封第一講書人閱讀 60,199評(píng)論 1 300
  • 正文 為了忘掉前任傲醉,我火速辦了婚禮,結(jié)果婚禮上呻率,老公的妹妹穿的比我還像新娘硬毕。我一直安慰自己,他們只是感情好筷凤,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,196評(píng)論 6 398
  • 文/花漫 我一把揭開白布昭殉。 她就那樣靜靜地躺著苞七,像睡著了一般藐守。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上蹂风,一...
    開封第一講書人閱讀 52,793評(píng)論 1 314
  • 那天卢厂,我揣著相機(jī)與錄音,去河邊找鬼惠啄。 笑死慎恒,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的撵渡。 我是一名探鬼主播融柬,決...
    沈念sama閱讀 41,221評(píng)論 3 423
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼趋距!你這毒婦竟也來了粒氧?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 40,174評(píng)論 0 277
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤节腐,失蹤者是張志新(化名)和其女友劉穎外盯,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體翼雀,經(jīng)...
    沈念sama閱讀 46,699評(píng)論 1 320
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡饱苟,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,770評(píng)論 3 343
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了狼渊。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片箱熬。...
    茶點(diǎn)故事閱讀 40,918評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖狈邑,靈堂內(nèi)的尸體忽然破棺而出城须,到底是詐尸還是另有隱情,我是刑警寧澤官地,帶...
    沈念sama閱讀 36,573評(píng)論 5 351
  • 正文 年R本政府宣布酿傍,位于F島的核電站,受9級(jí)特大地震影響驱入,放射性物質(zhì)發(fā)生泄漏赤炒。R本人自食惡果不足惜氯析,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,255評(píng)論 3 336
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望莺褒。 院中可真熱鬧掩缓,春花似錦、人聲如沸遵岩。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,749評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)尘执。三九已至舍哄,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間誊锭,已是汗流浹背表悬。 一陣腳步聲響...
    開封第一講書人閱讀 33,862評(píng)論 1 274
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留丧靡,地道東北人蟆沫。 一個(gè)月前我還...
    沈念sama閱讀 49,364評(píng)論 3 379
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像温治,于是被迫代替她去往敵國(guó)和親饭庞。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,926評(píng)論 2 361

推薦閱讀更多精彩內(nèi)容