vue生命週期

2021-10-09 11:54:01 字數 969 閱讀 1136

beforecreate建立created

beforemount掛載mounted

beforeupdate更新updated

beforedestroy銷毀destroyed

簡單粗暴的答案直接走起:

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例項銷毀;

是不是很簡單,看完了吸口氣

props => methods =>data => computed => watch

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...