Vue生命周期示例詳解
首先看看Vue文檔里關(guān)于實例生命周期的解釋圖

那么下面我們來進行測試一下
<section id="app-8">
{{data}}
</section>
var myVue=new Vue({
el:"#app-8",
data:{
data:"aaaaa",
info:"nono"
},
beforeCreate:function(){
console.log("創(chuàng)建前========")
console.log(this.data)
console.log(this.$el)
},
created:function(){
console.log("已創(chuàng)建========")
console.log(this.info)
console.log(this.$el)
},
beforeMount:function(){
console.log("mount之前========")
console.log(this.info)
console.log(this.$el)
},
mounted:function(){
console.log("mounted========")
console.log(this.info)
console.log(this.$el)
},
beforeUpdate:function(){
console.log("更新前========");
},
updated:function(){
console.log("更新完成========");
},
beforeDestroy:function(){
console.log("銷毀前========")
console.log(this.info)
console.log(this.$el)
},
destroyed:function(){
console.log("已銷毀========")
console.log(this.info)
console.log(this.$el)
}
})
代碼如上,瀏覽器開始加載文件



由上圖可知:
1、beforeCreate 此時$el、data 的值都為undefined
2、創(chuàng)建之后,此時可以拿到data的值,但是$el依舊為undefined
3、mount之前,$el的值為“虛擬”的元素節(jié)點
4、mount之后,mounted之前,“虛擬”的dom節(jié)點被真實的dom節(jié)點替換,并將其插入到dom樹中,于是在觸發(fā)mounted時,可以獲取到$el為真實的dom元素()
myVue.$el===document.getElementById("app-8") // true
接著,在console中修改data,更新視圖

觸發(fā)beforeUpdata 和updated
接著,執(zhí)行myVue.$destroy()

總結(jié)一下,對官方文檔的那張圖簡化一下,就得到了這張圖

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Vue form表單動態(tài)添加組件實戰(zhàn)案例
這篇文章主要介紹了Vue form表單動態(tài)添加組件實戰(zhàn)案例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-09-09
Vue router/Element重復(fù)點擊導(dǎo)航路由報錯問題及解決
這篇文章主要介紹了Vue router/Element重復(fù)點擊導(dǎo)航路由報錯問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-07-07
element-plus 如何設(shè)置 el-date-picker 彈出框位置
el-date-picker 組件會自動根據(jù)空間范圍進行選擇比較好的彈出位置,但特定情況下,它自動計算出的彈出位置并不符合我們的實際需求,故需要我們手動設(shè)置,這篇文章主要介紹了element-plus 如何設(shè)置 el-date-picker 彈出框位置,需要的朋友可以參考下2024-07-07
vue2.0 如何把子組件的數(shù)據(jù)傳給父組件(推薦)
這篇文章主要介紹了vue2.0 如何把子組件的數(shù)據(jù)傳給父組件,需要的朋友可以參考下2018-01-01

