簡單粗暴的答案直接走起:
1、建立vue例項,new vue()
;
2、在建立vue例項的時候,執行了init(),在init(初始化)過程中首先呼叫了beforecreate
鉤子函式;
3、同時監聽data資料,初始化vue內部事件,進行屬性和方法的計算;
4、以上都幹完了,呼叫created
鉤子函式(一般axios請求會在這個週期內進行);
5、模板編譯,把data物件裡面的資料和vue語法寫的模板編譯成html。編譯過程分三種情況:1)例項內部有template屬性,直接呼叫,然後呼叫render函式去渲染;2)沒有該屬性呼叫外部html;3)都沒有丟擲錯誤;
6、編譯模板完成,呼叫beforemount
鉤子函式;
7、render函式執行之後,將渲染出來的內容掛載到dom節點上;
8、掛在結束,呼叫mounted
鉤子函式;
9、資料發生變化,呼叫beforeupdate
鉤子函式,經歷virtual dom(虛擬dom);
10、更新完成,呼叫updated
鉤子函式;
11、beforedestory
銷毀所有觀察者、元件及事件監聽;
12、destoryed
例項銷毀;
vue生命週期
beforecreate 元件例項剛剛被建立,屬性都沒有 create 例項已經建立完成,屬性已經繫結 beforemount 模板編譯之前 mounted 模板編譯之後 beforeupdate 元件更新之前 updated 元件更新完畢 beforedestroy 元件銷毀之前 destroye...
vue生命週期
vue把整個生命週期劃分為建立 掛載 更新 銷毀等階段,每個階段都會給一些 鉤子 讓我們來做一些我們想實現的動作。學習例項的生命週期,能幫助我們理解vue例項的運作機制,更好地合理利用各個鉤子來完成我們的業務 我們分別來看看這幾個階段 1.beforecreate 此階段為例項初始化之後,此時的資料...
Vue 生命週期
import vue from vue el root 沒有的話,使用render,繼續沒有,就把el的outerhtml編譯成模板 template temp data beforecreate created el是原來的el beforemount 渲染函式 render h this.tex...