重學Vue--Vue生命周期

什么是Vue的生命周期?

從Vue實例創(chuàng)建、運行、到銷毀期間,總是伴隨著各種各樣的事件,這些事件,統(tǒng)稱為生命周期。

Vue生命周期的作用?

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

Vue生命周期過程?

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


Vue生命周期

用文字的方式敘述就是

  1. Vue的生命周期從創(chuàng)建一個Vue實例開始,之后Vue要進行初始化事件和初始化生命周期。
  2. 執(zhí)行beforeCreate鉤子函數(shù),這個函數(shù)執(zhí)行在初始化之后,創(chuàng)建組件之前,所以還不能訪問數(shù)據(jù),組件中的data,ref都為undefind。
  3. 進入了初始化中,初始化data和props,并且給數(shù)據(jù)綁定上數(shù)據(jù)劫持
  4. 執(zhí)行created鉤子函數(shù),這個函數(shù)在組件創(chuàng)建完成后立即被調(diào)用,組件中有了data對象,可以操作data,可以發(fā)請求和訪問數(shù)據(jù)了,ref依然為undefind。因為還沒有掛載,所以el不可用。
  5. 進行編譯選項,是否有el或template,再根據(jù)編譯選項作為模板將數(shù)據(jù)和compile函數(shù)(編譯函數(shù))進行結合,創(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. 當數(shù)據(jù)被更新時調(diào)用beforeUpdate鉤子函數(shù),它在頁面數(shù)據(jù)更新之前調(diào)用,并監(jiān)聽數(shù)據(jù)的變化,但不可以在這里更改數(shù)據(jù)
  2. 虛擬DOM重新渲染并應用更新
  3. updated數(shù)據(jù)更新完畢 在這個生命周期鉤子函數(shù)中 我們可以獲取到當前最新的數(shù)據(jù)(也就是頁面中的最新數(shù)據(jù))

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

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

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

鉤子函數(shù) 作用
?? ? ? ? ? ? ?? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? beforeCreate? ? ? ? ? ? ? ? ? ? ? ? ? ? ? 該函數(shù)執(zhí)行在組件創(chuàng)建、數(shù)據(jù)觀測 (data observer) 和 event/watcher 事件配置之前,實例初始化之后被調(diào)用。在該階段組件未創(chuàng)建,不能訪問數(shù)據(jù),組件中的 data,ref 均為 undefined。
Created ? ? ? ? ? ? ? ? ? ? 該函數(shù)在組件創(chuàng)建完成后被立即調(diào)用,在這一步,實例已完成以下的配置:數(shù)據(jù)觀測 (data observer),屬性和方法的運算,watch/event 事件回調(diào)。但是還未渲染成HTML模板,組件中的data對象已經(jīng)存在,可以對data進行操作了,即可以訪問數(shù)據(jù),發(fā)請求,ref依舊是undefined,掛載階段還沒開始,$el 屬性目前尚不可用。一般將數(shù)據(jù)的初始化和初始化頁面的請求放在這里面
?? ?? ? ? ?? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? BeforeMount ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? 該函數(shù)在組件掛載之前,在該階段頁面上還沒渲染出 HTML 元素,data 初始化完成,ref 依舊不可以操作,相關的 render 函數(shù)首次被調(diào)用。可以訪問數(shù)據(jù),編譯模板結束,虛擬 dom 已經(jīng)存在。該鉤子在服務器端渲染期間不被調(diào)用。
Mounted? ? ? ? ?? ? ? ? ? ? ? ? ? ? 該函數(shù)是頁面完成掛載之后執(zhí)行的,這時 el 被新創(chuàng)建的 vm.$el 替換了,就可以操作 ref 了,一般會用于將組件初始時請求數(shù)據(jù)的方法放到這里面,filter 也是在這里生效??梢阅玫綌?shù)據(jù)和節(jié)點,實例被掛載后調(diào)用。該鉤子在服務器端渲染期間不被調(diào)用。
? ??? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? BeforeUpdate ? ? ? ? ?? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? 該函數(shù)在數(shù)據(jù)更新時調(diào)用,發(fā)生在虛擬 DOM 打補丁之前。這里適合在更新之前訪問現(xiàn)有的 DOM,比如手動移除已添加的事件監(jiān)聽器。該鉤子在服務器端渲染期間不被調(diào)用,因為只有初次渲染會在服務端進行。
? ? ? ? ? ? ? ? ? ? Updated ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?? ? ? ? ? 由于數(shù)據(jù)更改導致的虛擬 DOM 重新渲染和打補丁,在這之后會調(diào)用該鉤子,在數(shù)據(jù)更新之后做一些處理,即監(jiān)控數(shù)據(jù)的變化。當這個鉤子被調(diào)用時,組件 DOM 已經(jīng)更新,所以你現(xiàn)在可以執(zhí)行依賴于 DOM 的操作。然而在大多數(shù)情況下,你應該避免在此期間更改狀態(tài)。如果要相應狀態(tài)改變,通常最好使用計算屬性或 watcher 取而代之。該鉤子在服務器端渲染期間不被調(diào)用。watch是監(jiān)控特定數(shù)據(jù)的變化,而updated是監(jiān)控組件里所有數(shù)據(jù)的變化。
?? ?? ? ? ? ? ? ? ? ? ? ? ? ? ?? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? BeforeDestroy? ? ? ? ?? ?? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? 該函數(shù)在實例銷毀之前調(diào)用,這里的 ref 依舊可以操作,實例仍然完全可用,可以在這里做清除定時器的操作,防止內(nèi)存泄漏。該鉤子在服務器端渲染期間不被調(diào)用。
???? ? ?? ? ? ?? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? Destroyed? ? ? ? ? ? ? ? ? ? ?? ? ? ? ? ? ? ? ? 該函數(shù)在組件銷毀的時候執(zhí)行,即實例銷毀后調(diào)用,這里的 ref 不存在。該鉤子被調(diào)用后,對應 Vue 實例的所有指令都被解綁,所有的事件監(jiān)聽器被移除,所有的子實例也都被銷毀。該鉤子在服務器端渲染期間不被調(diào)用。

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

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

后記

這是我總結的關于Vue生命周期的一些知識,如有錯誤希望小伙伴們熱心的告訴我,我及時改正。

參考

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

最后編輯于
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,460評論 6 538
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 99,067評論 3 423
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事?!?“怎么了?”我有些...
    開封第一講書人閱讀 177,467評論 0 382
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,468評論 1 316
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,184評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,582評論 1 325
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,616評論 3 444
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,794評論 0 289
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,343評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 41,096評論 3 356
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,291評論 1 371
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,863評論 5 362
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 44,513評論 3 348
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,941評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,190評論 1 291
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,026評論 3 396
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,253評論 2 375