基于Vue實(shí)例生命周期(全面解析)
前面的話
Vue實(shí)例在創(chuàng)建時(shí)有一系列的初始化步驟,例如建立數(shù)據(jù)觀察,編譯模板,創(chuàng)建數(shù)據(jù)綁定等。在此過程中,我們可以通過一些定義好的生命周期鉤子函數(shù)來運(yùn)行業(yè)務(wù)邏輯。本文將詳細(xì)介紹Vue實(shí)例的生命周期
圖示
下圖是Vue實(shí)例生命周期的圖示

解釋
接下來,根據(jù)提供的生命周期鉤子,對(duì)Vue實(shí)例各個(gè)階段的情況進(jìn)行詳細(xì)說明
【beforeCreate】
在實(shí)例開始初始化時(shí)同步調(diào)用。此時(shí)數(shù)據(jù)觀測(cè)、事件等都尚未初始化
【created】
在實(shí)例創(chuàng)建之后調(diào)用。此時(shí)已完成數(shù)據(jù)觀測(cè)、事件方法,但尚未開始DOM編譯,即未掛載到document中
【beforeMount】
在mounted之前運(yùn)行
【mounted】
在編譯結(jié)束時(shí)調(diào)用。此時(shí)所有指令已生效,數(shù)據(jù)變化已能觸發(fā)DOM更新,但不保證$el已插入文檔
【beforeUpdate】
在實(shí)例掛載之后,再次更新實(shí)例(例如更新 data)時(shí)會(huì)調(diào)用該方法,此時(shí)尚未更新DOM結(jié)構(gòu)
【updated】
在實(shí)例掛載之后,再次更新實(shí)例并更新完DOM結(jié)構(gòu)后調(diào)用
【beforeDestroy】
在開始銷毀實(shí)例時(shí)調(diào)用,此刻實(shí)例仍然有效
【destroyed】
在實(shí)例被銷毀之后調(diào)用。此時(shí)所有綁定和實(shí)例指令都已經(jīng)解綁,子實(shí)例也被銷毀
【activated】
需要配合動(dòng)態(tài)組件keep-live屬性使用。在動(dòng)態(tài)組件初始化渲染的過程中調(diào)用該方法
【deactivated】
需要配合動(dòng)態(tài)組件keep-live屬性使用。在動(dòng)態(tài)組件初始化移出的過程中調(diào)用該方法
簡(jiǎn)單實(shí)例
下面寫一個(gè)簡(jiǎn)單實(shí)例來更清楚地了解Vue實(shí)例內(nèi)部的運(yùn)行機(jī)制
<div id="example">{{message}}</div>
<script> var vm = new Vue({ el: '#example', data:{ message:'match' }, beforeCreate(){ console.log('beforeCreate'); }, created(){ console.log('created'); }, beforeMount(){ console.log('beforeMount'); }, mounted(){ console.log('mounted'); }, beforeUpdate(){ console.log('beforeUpdate'); }, updated(){ console.log('updated'); //組件更新后調(diào)用$destroyed函數(shù),進(jìn)行銷毀 this.$destroy(); }, beforeDestroy(){ console.log('beforeDestroy'); }, destroyed(){ console.log('destroyed'); }, }) </script>

以上這篇基于Vue實(shí)例生命周期(全面解析)就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
el-table 選擇框根據(jù)條件設(shè)置某項(xiàng)不可選中的操作代碼
這篇文章主要介紹了el-table 選擇框根據(jù)條件設(shè)置某項(xiàng)不可選中的操作代碼,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2024-03-03vue-pdf插件實(shí)現(xiàn)pdf文檔預(yù)覽方式(自動(dòng)分頁(yè)預(yù)覽)
這篇文章主要介紹了vue-pdf插件實(shí)現(xiàn)pdf文檔預(yù)覽方式(自動(dòng)分頁(yè)預(yù)覽),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-03-03vue2結(jié)合element-ui實(shí)現(xiàn)TreeSelect樹選擇功能
這篇文章主要為大家詳細(xì)介紹了vue2如何結(jié)合element-ui實(shí)現(xiàn)TreeSelect樹選擇功能,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解下2024-03-03Vue3 + TypeScript 開發(fā)總結(jié)
本文直接上 Vue3 + TypeScript + Element Plus 開發(fā)的內(nèi)容,感興趣的話一起來看看吧2021-08-08vue項(xiàng)目中openlayers繪制行政區(qū)劃
這篇文章主要為大家詳細(xì)介紹了vue項(xiàng)目中openlayers繪制行政區(qū)劃,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-12-12vue項(xiàng)目實(shí)現(xiàn)表單登錄頁(yè)保存賬號(hào)和密碼到cookie功能
這篇文章主要介紹了vue項(xiàng)目實(shí)現(xiàn)表單登錄頁(yè)保存賬號(hào)和密碼到cookie功能,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-08-08vue3.x中useRouter()執(zhí)行后返回值是undefined問題解決
這篇文章主要給大家介紹了關(guān)于vue3.x中useRouter()執(zhí)行后返回值是undefined問題的解決方法,文中通過代碼示例介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用vue3.x具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-09-09