詳解Vue生命周期和MVVM框架
生命周期
組件從開始到結(jié)束的全過(guò)程
創(chuàng)建階段:beforeCreate、created掛載階段:beforeMount、mounted
更新階段:beforeUpdate、updated
組件從開始到結(jié)束的全過(guò)程
- 創(chuàng)建階段:beforeCreate、created
- 掛載階段:beforeMount、mounted
更新階段:beforeUpdate、updated
- 銷毀階段:beforeDestroy、destroyed
與動(dòng)態(tài)組件有關(guān)的兩個(gè)特殊的鉤子:
與組件異常捕獲有關(guān)的一個(gè)鉤子:
生命周期有哪些
- beforeCreate:聲明methods方法,聲明生命周期鉤子
- created:注入provide數(shù)據(jù),響應(yīng)式劫持、把data上數(shù)據(jù)遍歷后放在this上
- beforeMount:通過(guò)el/$mount/template找視圖模板,把template視圖模板編譯成render() (render方法是用于創(chuàng)建虛擬DOM的)
- mounted:創(chuàng)建$el掛載節(jié)點(diǎn),調(diào)用render()方法第一次生成虛擬DOM(Vnode是對(duì)真實(shí)視圖結(jié)構(gòu)的一種數(shù)據(jù)描述),Vue開始編譯工作,循環(huán)遞歸,指令和聲明式變量進(jìn)行touch,依賴收集、通知Watcher第一次完成DOM渲染
- beforeUpdate:網(wǎng)頁(yè)呈現(xiàn)在你的面前上,當(dāng)各種事件交互觸發(fā)data變化時(shí)
- updated:再次調(diào)用render()方法生成新的虛擬DOM(現(xiàn)在就有了兩個(gè)虛擬DOM,執(zhí)行patch運(yùn)算(diff運(yùn)算)找出兩個(gè)虛擬DOM之間的最小差異(臟節(jié)點(diǎn)集合),通過(guò)一個(gè)隊(duì)列進(jìn)行異步更新。
- beforeDestroy:當(dāng)調(diào)用$destroy()或路由切換時(shí),即將進(jìn)入銷毀階段
- destroyed:移除當(dāng)前組件的Watcher(DOM將無(wú)法再更新了),拆卸掉所有的子組件,移除事件監(jiān)聽器(wacth等等)
const app = new Vue({
data () {
return {
num: 1
}
},
watch: {
num () {
console.log('--- num changed')
}
},
// 聲明methods方法
// 聲明生命周期鉤子
beforeCreate () {
console.log('---beforeCreate')
},
// 注入provide數(shù)據(jù)
// 響應(yīng)式劫持、把data上數(shù)據(jù)遍歷后放在this上
created () {
console.log('---created')
// 調(diào)接口
},
// 通過(guò)el/$mount/template找視圖模板
// 把template視圖模板編譯成render() (render方法是用于創(chuàng)建虛擬DOM的)
beforeMount () {
console.log('---beforeMount')
},
// 創(chuàng)建$el掛載節(jié)點(diǎn)
// 調(diào)用render()方法第一次生成虛擬DOM(Vnode是對(duì)真實(shí)視圖結(jié)構(gòu)的一種數(shù)據(jù)描述)
// Vue開始編譯工作,循環(huán)遞歸,指令和聲明式變量進(jìn)行touch,依賴收集、通知Watcher第一次完成DOM渲染
mounted () {
console.log('---mounted')
// 調(diào)接口、開定時(shí)器、建立websocket長(zhǎng)連接、echarts圖表實(shí)例化、DOM/BOM操作。。。
},
// 網(wǎng)頁(yè)呈現(xiàn)你的面前上,當(dāng)各種事件交互觸發(fā)data變化時(shí)
beforeUpdate () {
console.log('---beforeUpdate')
},
// 再次調(diào)用render()方法生成新的虛擬DOM(現(xiàn)在就有了兩個(gè)虛擬DOM)
// 執(zhí)行patch運(yùn)算(diff運(yùn)算)找出兩個(gè)虛擬DOM之間的最小差異(臟節(jié)點(diǎn)集合),通過(guò)一個(gè)隊(duì)列進(jìn)行異步更新。
updated () {
console.log('---updated')
// updated在某些場(chǎng)景下,可以模擬出watch/$nextTick()的功能。
},
// 當(dāng)調(diào)用$destroy()或路由切換時(shí),即將進(jìn)入銷毀階段
beforeDestroy () {
console.log('---beforeDestroy')
// 清除定時(shí)器、清除緩存
},
// 移除當(dāng)前組件的Watcher(DOM將無(wú)法再更新了)
// 拆卸掉所有的子組件
// 移除事件監(jiān)聽器(wacth等等)
destroyed () {
console.log('---destroyed')
},
methods: {
add () {
console.log('---add')
this.num++
}
}
})
app.$mount('#app')app.$mount('#app')和el:'#app'都是掛載到真實(shí)DOM中。
什么是虛擬DOM
是一個(gè)很大的JSON數(shù)據(jù),用于描述視圖模板的,保存在內(nèi)存中。
虛擬DOM存在的價(jià)值點(diǎn)
更新,把DOM更新粒度降到最低,規(guī)避人為DOM濫操作。
什么是diff運(yùn)算
在更新階段,patch對(duì)新舊虛擬DOM進(jìn)行對(duì)比,找出臟節(jié)點(diǎn),提交更新。
什么是MVVM框架
MVVM流程 : M數(shù)據(jù)層 -> VM虛擬DOM層 -> V視圖層
網(wǎng)頁(yè)本質(zhì) = M數(shù)據(jù)層 + V視圖結(jié)構(gòu)
到此這篇關(guān)于Vue生命周期和MVVM框架的文章就介紹到這了,更多相關(guān)Vue生命周期和MVVM框架內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
在Vue3中使用Vue Tour實(shí)現(xiàn)頁(yè)面導(dǎo)覽
Vue Tour 是一個(gè)方便的 Vue.js 插件,它可以幫助我們?cè)诰W(wǎng)站或應(yīng)用中實(shí)現(xiàn)簡(jiǎn)單而靈活的頁(yè)面導(dǎo)覽功能,本文我們將介紹如何在 Vue 3 中使用 Vue Tour,并通過(guò)示例代碼演示其基本用法,需要的朋友可以參考下2024-04-04
vue.js頁(yè)面加載執(zhí)行created,mounted的先后順序說(shuō)明
這篇文章主要介紹了vue.js頁(yè)面加載執(zhí)行created,mounted的先后順序說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-11-11
基于webpack4+vue-cli3項(xiàng)目實(shí)現(xiàn)換膚功能
這篇文章主要介紹了基于webpack4+vue-cli3項(xiàng)目的換膚功能,文中是通過(guò)scss+style-loader/useable做換膚功能,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-07-07
一文詳解Vue3的watch是如何實(shí)現(xiàn)監(jiān)聽的
watch這個(gè)API大家都很熟悉,今天這篇文章小編來(lái)帶你搞清楚Vue3的watch是如何實(shí)現(xiàn)對(duì)響應(yīng)式數(shù)據(jù)進(jìn)行監(jiān)聽的,希望對(duì)大家有一定的幫助2024-11-11
Vue3 + TypeScript 開發(fā)總結(jié)
本文直接上 Vue3 + TypeScript + Element Plus 開發(fā)的內(nèi)容,感興趣的話一起來(lái)看看吧2021-08-08
vue單個(gè)組件實(shí)現(xiàn)無(wú)限層級(jí)多選菜單功能
這篇文章主要介紹了vue單個(gè)組件實(shí)現(xiàn)無(wú)限層級(jí)多選菜單的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2018-04-04
詳解Vue學(xué)習(xí)筆記入門篇之組件的內(nèi)容分發(fā)(slot)
這篇文章主要介紹了詳解Vue學(xué)習(xí)筆記入門篇之組件的內(nèi)容分發(fā)(slot),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-07-07
實(shí)例詳解Vue項(xiàng)目使用eslint + prettier規(guī)范代碼風(fēng)格
這篇文章主要介紹了Vue項(xiàng)目使用eslint + prettier規(guī)范代碼風(fēng)格,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2018-08-08

