【React Native學(xué)習(xí)筆記三】組件的聲明周期與通信

一、組件的生命周期

1咳胃、生命周期函數(shù)介紹:

(1)初始化

【1】constructor

【2】componentWillMount(只執(zhí)行一次 )

【3】render

【4】componentDidMount(只執(zhí)行一次)

(2)運(yùn)行期

【1】state改變

【2】props變化

(3)結(jié)束期

【1】componentWillUnmount

2咏雌、定時(shí)器程序舉例:

class App extends Component {

state = {

count:10

};

//聲明周期一

render() {

const {count} = this.state;

return (

{this.state.count}

)

}

//生命周期二

componentDidMount(){

this.timer = setInterval(()=>{

const {count} = this.state;

if(count === 0) {

return clearInterval(this.timer);

}

this.setState({

count:count-1

});

}, 1000);

}

//聲明周期三

componentWillUnmount(){

clearInterval(this.timer);

}

}

3胆萧、生命周期函數(shù)總結(jié)

(1)render中只做渲染相關(guān)的操作

(2)隨組件加載只執(zhí)行一次的操作,放在WillMount或DidMount中

(3)聲明周期函數(shù)不能是阻塞的镊叁!

(4)記得在willUnmount中銷毀定時(shí)器和一些訂閱事件

(5)props發(fā)生變化柠辞,使用willReceiveProps來(lái)處理

4团秽、注意點(diǎn):

(1)定時(shí)器函數(shù)

【1】setTimeout只執(zhí)行一次

【2】setInterval循環(huán)執(zhí)行

(2)生命周期函數(shù)和自定義函數(shù)區(qū)別

【1】生命周期函數(shù)寫法:

renderResult=()=>{ }

【2】自定義函數(shù)寫法:

render() { }

5、如何在render中根據(jù)不同條件渲染不同結(jié)果?

6徙垫、何時(shí)用props讥裤,何時(shí)用state?

(1)子控件中姻报,props可以作為state的初始值

在render中己英,state = {

count: this.props.time

}

此時(shí),傳參只是第一次有效吴旋。

(2)子控件如何獲得變化后的props损肛?

componentWillReceiveProps(nextProps) {

this.setState({

});

}

二、組件間通信

1荣瑟、父組件向子組件通信治拿、子組件之間通信

(1)注意事項(xiàng):

【1】父組件以自身的state作為子組件的props;父組件調(diào)用setState笆焰,于是子組件的props相應(yīng)變化劫谅。

【2】Component中若使用state而不是props渲染,則使用componentWillReceiveProps生命周期函數(shù)

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末嚷掠,一起剝皮案震驚了整個(gè)濱河市捏检,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌不皆,老刑警劉巖贯城,帶你破解...
    沈念sama閱讀 216,496評(píng)論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異霹娄,居然都是意外死亡能犯,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,407評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門犬耻,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)踩晶,“玉大人,你說(shuō)我怎么就攤上這事香追『掀埃” “怎么了坦胶?”我有些...
    開封第一講書人閱讀 162,632評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵透典,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我顿苇,道長(zhǎng)峭咒,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,180評(píng)論 1 292
  • 正文 為了忘掉前任纪岁,我火速辦了婚禮凑队,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己漩氨,他們只是感情好西壮,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,198評(píng)論 6 388
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著叫惊,像睡著了一般款青。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上霍狰,一...
    開封第一講書人閱讀 51,165評(píng)論 1 299
  • 那天抡草,我揣著相機(jī)與錄音,去河邊找鬼蔗坯。 笑死康震,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的宾濒。 我是一名探鬼主播腿短,決...
    沈念sama閱讀 40,052評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼绘梦!你這毒婦竟也來(lái)了答姥?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,910評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤谚咬,失蹤者是張志新(化名)和其女友劉穎鹦付,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體择卦,經(jīng)...
    沈念sama閱讀 45,324評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡敲长,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,542評(píng)論 2 332
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了秉继。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片祈噪。...
    茶點(diǎn)故事閱讀 39,711評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖尚辑,靈堂內(nèi)的尸體忽然破棺而出辑鲤,到底是詐尸還是另有隱情,我是刑警寧澤杠茬,帶...
    沈念sama閱讀 35,424評(píng)論 5 343
  • 正文 年R本政府宣布月褥,位于F島的核電站,受9級(jí)特大地震影響瓢喉,放射性物質(zhì)發(fā)生泄漏宁赤。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,017評(píng)論 3 326
  • 文/蒙蒙 一栓票、第九天 我趴在偏房一處隱蔽的房頂上張望决左。 院中可真熱鬧,春花似錦、人聲如沸佛猛。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,668評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)继找。三九已至强衡,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間码荔,已是汗流浹背漩勤。 一陣腳步聲響...
    開封第一講書人閱讀 32,823評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留缩搅,地道東北人越败。 一個(gè)月前我還...
    沈念sama閱讀 47,722評(píng)論 2 368
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像硼瓣,于是被迫代替她去往敵國(guó)和親究飞。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,611評(píng)論 2 353

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