重學(xué)Vue--Vue生命周期

什么是Vue的生命周期遇骑?

從Vue實(shí)例創(chuàng)建、運(yùn)行揖曾、到銷毀期間落萎,總是伴隨著各種各樣的事件,這些事件翩肌,統(tǒng)稱為生命周期模暗。

Vue生命周期的作用?

在Vue生命周期中會伴隨多個事件鉤子念祭,這些事件鉤子在控制整個Vue實(shí)例中可以形成更好的邏輯。
Vue生命周期總共分為 : 初始化 前后碍侦,創(chuàng)建前后粱坤,更新前后,銷毀前后

Vue生命周期過程瓷产?

Vue的生命周期過程在官網(wǎng)中給出了一張圖片可以幫助我們很好的理解


Vue生命周期

用文字的方式敘述就是

  1. Vue的生命周期從創(chuàng)建一個Vue實(shí)例開始站玄,之后Vue要進(jìn)行初始化事件和初始化生命周期。
  2. 執(zhí)行beforeCreate鉤子函數(shù)濒旦,這個函數(shù)執(zhí)行在初始化之后株旷,創(chuàng)建組件之前,所以還不能訪問數(shù)據(jù)尔邓,組件中的data晾剖,ref都為undefind。
  3. 進(jìn)入了初始化中梯嗽,初始化data和props齿尽,并且給數(shù)據(jù)綁定上數(shù)據(jù)劫持
  4. 執(zhí)行created鉤子函數(shù),這個函數(shù)在組件創(chuàng)建完成后立即被調(diào)用灯节,組件中有了data對象循头,可以操作data绵估,可以發(fā)請求和訪問數(shù)據(jù)了,ref依然為undefind卡骂。因?yàn)檫€沒有掛載国裳,所以el不可用。
  5. 進(jìn)行編譯選項(xiàng)全跨,是否有el或template躏救,再根據(jù)編譯選項(xiàng)作為模板將數(shù)據(jù)和compile函數(shù)(編譯函數(shù))進(jìn)行結(jié)合,創(chuàng)建出虛擬DOM對象螟蒸。

以上初始化階段完成盒使,下面來描述創(chuàng)建過程

  1. 數(shù)據(jù)掛載前先執(zhí)行beforeMount鉤子函數(shù),頁面還沒有創(chuàng)建出HTML元素七嫌,data初始化已經(jīng)完成少办,虛擬dom已經(jīng)存在
  2. 創(chuàng)建vm.$el來替換el,并切換掉原有的編譯模板诵原,生成一個真正可用的HTML
  3. 完成頁面的數(shù)據(jù)掛載后執(zhí)行Mounted英妓,這時可以操作數(shù)據(jù)和DOM了

以上,創(chuàng)建階段描述完了绍赛,接下來是數(shù)據(jù)更新時

  1. 當(dāng)數(shù)據(jù)被更新時調(diào)用beforeUpdate鉤子函數(shù)蔓纠,它在頁面數(shù)據(jù)更新之前調(diào)用,并監(jiān)聽數(shù)據(jù)的變化吗蚌,但不可以在這里更改數(shù)據(jù)
  2. 虛擬DOM重新渲染并應(yīng)用更新
  3. updated數(shù)據(jù)更新完畢 在這個生命周期鉤子函數(shù)中 我們可以獲取到當(dāng)前最新的數(shù)據(jù)(也就是頁面中的最新數(shù)據(jù))

以上腿倚,更新階段描述完了,接下來是銷毀階段

  1. 當(dāng)調(diào)用vm.$destroy()函數(shù)時蚯妇,進(jìn)入銷毀階段
  2. beforeDestroy 銷毀之前 還是可以使用HTML的敷燎,也可以獲取到數(shù)據(jù)
  3. 銷毀中 終止對象劫持(最主要)子組件,事件
  4. destroyed 銷毀之后 我們對 Vue實(shí)例提供的DOM操作就無效了 但是還是可以獲取到數(shù)據(jù)的

Vue生命周期鉤子函數(shù)箩言?

鉤子函數(shù) 作用
?? ? ? ? ? ? ?? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? beforeCreate? ? ? ? ? ? ? ? ? ? ? ? ? ? ? 該函數(shù)執(zhí)行在組件創(chuàng)建硬贯、數(shù)據(jù)觀測 (data observer) 和 event/watcher 事件配置之前,實(shí)例初始化之后被調(diào)用陨收。在該階段組件未創(chuàng)建饭豹,不能訪問數(shù)據(jù),組件中的 data务漩,ref 均為 undefined拄衰。
Created ? ? ? ? ? ? ? ? ? ? 該函數(shù)在組件創(chuàng)建完成后被立即調(diào)用,在這一步菲饼,實(shí)例已完成以下的配置:數(shù)據(jù)觀測 (data observer)肾砂,屬性和方法的運(yùn)算,watch/event 事件回調(diào)宏悦。但是還未渲染成HTML模板镐确,組件中的data對象已經(jīng)存在包吝,可以對data進(jìn)行操作了,即可以訪問數(shù)據(jù)源葫,發(fā)請求诗越,ref依舊是undefined,掛載階段還沒開始息堂,$el 屬性目前尚不可用嚷狞。一般將數(shù)據(jù)的初始化和初始化頁面的請求放在這里面
?? ?? ? ? ?? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? BeforeMount ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? 該函數(shù)在組件掛載之前,在該階段頁面上還沒渲染出 HTML 元素荣堰,data 初始化完成床未,ref 依舊不可以操作,相關(guān)的 render 函數(shù)首次被調(diào)用振坚∞备椋可以訪問數(shù)據(jù),編譯模板結(jié)束渡八,虛擬 dom 已經(jīng)存在啃洋。該鉤子在服務(wù)器端渲染期間不被調(diào)用。
Mounted? ? ? ? ?? ? ? ? ? ? ? ? ? ? 該函數(shù)是頁面完成掛載之后執(zhí)行的屎鳍,這時 el 被新創(chuàng)建的 vm.$el 替換了宏娄,就可以操作 ref 了,一般會用于將組件初始時請求數(shù)據(jù)的方法放到這里面逮壁,filter 也是在這里生效孵坚。可以拿到數(shù)據(jù)和節(jié)點(diǎn)貌踏,實(shí)例被掛載后調(diào)用十饥。該鉤子在服務(wù)器端渲染期間不被調(diào)用。
? ??? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? BeforeUpdate ? ? ? ? ?? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? 該函數(shù)在數(shù)據(jù)更新時調(diào)用祖乳,發(fā)生在虛擬 DOM 打補(bǔ)丁之前。這里適合在更新之前訪問現(xiàn)有的 DOM秉氧,比如手動移除已添加的事件監(jiān)聽器眷昆。該鉤子在服務(wù)器端渲染期間不被調(diào)用,因?yàn)橹挥谐醮武秩緯诜?wù)端進(jìn)行汁咏。
? ? ? ? ? ? ? ? ? ? Updated ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?? ? ? ? ? 由于數(shù)據(jù)更改導(dǎo)致的虛擬 DOM 重新渲染和打補(bǔ)丁亚斋,在這之后會調(diào)用該鉤子,在數(shù)據(jù)更新之后做一些處理攘滩,即監(jiān)控?cái)?shù)據(jù)的變化帅刊。當(dāng)這個鉤子被調(diào)用時,組件 DOM 已經(jīng)更新漂问,所以你現(xiàn)在可以執(zhí)行依賴于 DOM 的操作赖瞒。然而在大多數(shù)情況下女揭,你應(yīng)該避免在此期間更改狀態(tài)。如果要相應(yīng)狀態(tài)改變栏饮,通常最好使用計(jì)算屬性或 watcher 取而代之吧兔。該鉤子在服務(wù)器端渲染期間不被調(diào)用。watch是監(jiān)控特定數(shù)據(jù)的變化袍嬉,而updated是監(jiān)控組件里所有數(shù)據(jù)的變化境蔼。
?? ?? ? ? ? ? ? ? ? ? ? ? ? ? ?? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? BeforeDestroy? ? ? ? ?? ?? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? 該函數(shù)在實(shí)例銷毀之前調(diào)用,這里的 ref 依舊可以操作伺通,實(shí)例仍然完全可用箍土,可以在這里做清除定時器的操作,防止內(nèi)存泄漏罐监。該鉤子在服務(wù)器端渲染期間不被調(diào)用吴藻。
???? ? ?? ? ? ?? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? Destroyed? ? ? ? ? ? ? ? ? ? ?? ? ? ? ? ? ? ? ? 該函數(shù)在組件銷毀的時候執(zhí)行,即實(shí)例銷毀后調(diào)用笑诅,這里的 ref 不存在诊赊。該鉤子被調(diào)用后,對應(yīng) Vue 實(shí)例的所有指令都被解綁月弛,所有的事件監(jiān)聽器被移除尊沸,所有的子實(shí)例也都被銷毀。該鉤子在服務(wù)器端渲染期間不被調(diào)用妇多。

另外在使用keep-alive 時還存在兩個鉤子函數(shù)

鉤子函數(shù) 作用
Activated 被 keep-alive 緩存的組件激活時調(diào)用伤哺。該鉤子在服務(wù)器端渲染期間不被調(diào)用。
Deactivated 被 keep-alive 緩存的組件停用時調(diào)用者祖。該鉤子在服務(wù)器端渲染期間不被調(diào)用立莉。

后記

這是我總結(jié)的關(guān)于Vue生命周期的一些知識,如有錯誤希望小伙伴們熱心的告訴我七问,我及時改正蜓耻。

參考

Vue的生命周期(簡單的過程)

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市械巡,隨后出現(xiàn)的幾起案子刹淌,更是在濱河造成了極大的恐慌,老刑警劉巖讥耗,帶你破解...
    沈念sama閱讀 219,039評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件有勾,死亡現(xiàn)場離奇詭異,居然都是意外死亡古程,警方通過查閱死者的電腦和手機(jī)蔼卡,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,426評論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來挣磨,“玉大人雇逞,你說我怎么就攤上這事荤懂。” “怎么了喝峦?”我有些...
    開封第一講書人閱讀 165,417評論 0 356
  • 文/不壞的土叔 我叫張陵势誊,是天一觀的道長。 經(jīng)常有香客問我谣蠢,道長粟耻,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,868評論 1 295
  • 正文 為了忘掉前任眉踱,我火速辦了婚禮挤忙,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘谈喳。我一直安慰自己册烈,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,892評論 6 392
  • 文/花漫 我一把揭開白布婿禽。 她就那樣靜靜地躺著赏僧,像睡著了一般。 火紅的嫁衣襯著肌膚如雪扭倾。 梳的紋絲不亂的頭發(fā)上淀零,一...
    開封第一講書人閱讀 51,692評論 1 305
  • 那天,我揣著相機(jī)與錄音膛壹,去河邊找鬼驾中。 笑死,一個胖子當(dāng)著我的面吹牛模聋,可吹牛的內(nèi)容都是我干的肩民。 我是一名探鬼主播,決...
    沈念sama閱讀 40,416評論 3 419
  • 文/蒼蘭香墨 我猛地睜開眼链方,長吁一口氣:“原來是場噩夢啊……” “哼持痰!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起祟蚀,我...
    開封第一講書人閱讀 39,326評論 0 276
  • 序言:老撾萬榮一對情侶失蹤共啃,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后暂题,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,782評論 1 316
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡究珊,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,957評論 3 337
  • 正文 我和宋清朗相戀三年薪者,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片剿涮。...
    茶點(diǎn)故事閱讀 40,102評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡言津,死狀恐怖攻人,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情悬槽,我是刑警寧澤怀吻,帶...
    沈念sama閱讀 35,790評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站初婆,受9級特大地震影響蓬坡,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜磅叛,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,442評論 3 331
  • 文/蒙蒙 一屑咳、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧弊琴,春花似錦兆龙、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,996評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至腋寨,卻和暖如春聪铺,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背精置。 一陣腳步聲響...
    開封第一講書人閱讀 33,113評論 1 272
  • 我被黑心中介騙來泰國打工计寇, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人脂倦。 一個月前我還...
    沈念sama閱讀 48,332評論 3 373
  • 正文 我出身青樓番宁,卻偏偏與公主長得像,于是被迫代替她去往敵國和親赖阻。 傳聞我的和親對象是個殘疾皇子蝶押,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,044評論 2 355