vue生命周期的探索
那么進入某個路由對應(yīng)的組件的時候,我們會觸發(fā)哪些類型的周期呢?
- 根實例的加載相關(guān)的生命周期(beforeCreate、created、beforeMount、mounted)
- 組件實例的加載相關(guān)的生命周期(beforeCreate、created、beforeMount、mounted)
- 全局路由勾子(router.beforeEach)
- 組件路由勾子(beforeRouteEnter)
- 組件路由勾子的next里的回調(diào)(beforeRouteEnter)
- 指令的周期(bind,inserted)
- nextTick方法的回調(diào)
接下來,讓我們用vue-cli簡單改造后的項目,做一個測試,看看各個聲明周期的觸發(fā)順序是怎樣的
main.js:
router.beforeEach((to, from, next) => {
console.log('路由全局勾子:beforeEach')
next()
})
router.afterEach((to, from) => {
console.log('路由全局勾子:afterEach')
})
new Vue({
beforeCreate () {
console.log('根組件:beforeCreate')
},
created () {
console.log('根組件:created')
},
beforeMount () {
console.log('根組件:beforeMount')
},
mounted () {
console.log('根組件:mounted')
}
el: '#app',
router,
template: '<App/>',
components: { App }
})
test.vue
<template>
<h1 v-ooo @click = "$router.push('/')">test</h1>
</template>
<script>
export default {
beforeRouteEnter (to, from, next) {
console.log('組件路由勾子:beforeRouteEnter')
next(vm => {
console.log('組件路由勾子beforeRouteEnter的next')
})
},
beforeCreate () {
console.log('組件:beforeCreate')
},
created () {
this.$nextTick(() => {
console.log('nextTick')
})
console.log('組件:created')
},
beforeMount () {
console.log('組件:beforeMount')
},
mounted () {
console.log('組件:mounted')
},
directives: {
ooo: {
bind (el, binding, vnode) {
console.log('指令binding')
},
inserted (el, binding, vnode) {
console.log('指令inserted')
}
}
}
}
</script>
接下來,直接進入test.vue對應(yīng)的路由。在控制臺,我們看到如下的輸出

我們看到執(zhí)行的順序為
- 路由勾子 (beforeEach、beforeRouteEnter、afterEach)
- 根組件 (beforeCreate、created、beforeMount)
- 組件 (beforeCreate、created、beforeMount)
- 指令 (bind、inserted)
- 組件 mounted
- 根組件 mounted
- beforeRouteEnter的next的回調(diào)
- nextTick
結(jié)論
路由勾子執(zhí)行周期非常早,甚至在根實例的渲染之前
具體的順序 router.beforeEach > beforeRouteEnter > router.afterEach
tip:在進行路由攔截的時候要避免使用實例內(nèi)部的方法或?qū)傩浴?br /> 在開發(fā)項目時候,我們腦門一拍把,具體攔截的程序,寫在了根實例的方法上了,到beforeEach去調(diào)用。
結(jié)果導(dǎo)致整個攔截的周期,推遲到實例渲染的之后。
因此對于一些路由組件的beforeRouteEnter里的請求并無法攔截,頁面看上去好像已經(jīng)攔截下來了。
實際上請求依然發(fā)了出去,beforeRouteEnter內(nèi)的函數(shù)依然執(zhí)行了。
指令的綁定在組件mounted之前,組件的beforeMount之后
不得不提的, beforeRouteEnter的next勾子
beforeRouteEnter的執(zhí)行順序是如此靠前,而其中next的回調(diào)勾子的函數(shù),執(zhí)行則非??亢?,在mounted之后?。?br />
我們通常是在beforeRouteEnter中加載一些首屏用數(shù)據(jù),待數(shù)據(jù)收到后,再調(diào)用next勾子,通過回調(diào)的參數(shù)vm將數(shù)據(jù)綁定到實例上。
因此,請注意next的勾子是非??亢蟮摹?/p>
nextTick
越早注冊的nextTick觸發(fā)越早
以上所述是小編給大家介紹的vue生命周期的探索詳解整合,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
Flutter部件內(nèi)部狀態(tài)管理小結(jié)之實現(xiàn)Vue的v-model功能
本文是 Flutter 部件內(nèi)部狀態(tài)管理的小結(jié),從部件的基礎(chǔ)開始,到部件的狀態(tài)管理,并且在過程中實現(xiàn)一個類似 Vue 的 v-model 的功能,感興趣的朋友跟隨小編一起看看吧2019-06-06
Vue中調(diào)用組件使用kebab-case短橫線命名法和使用大駝峰的區(qū)別詳解
這篇文章主要介紹了Vue中調(diào)用組件使用kebab-case(短橫線)命名法和使用大駝峰的區(qū)別,通過實例可以看出如果是在html中使用組件,那么就不能用大駝峰式寫法,如果是在.vue?文件中就可以,需要的朋友可以參考下2023-10-10
詳解如何創(chuàng)建并發(fā)布一個 vue 組件
這篇文章主要介紹了詳解如何創(chuàng)建并發(fā)布一個vue組件,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-11-11
Vue2安裝使用MonacoEditor方式(自定義語法,自定義高亮,自定義提示)
這篇文章主要介紹了Vue2安裝使用MonacoEditor方式(自定義語法,自定義高亮,自定義提示),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-04-04
vue3中如何使用ref和reactive定義和修改響應(yīng)式數(shù)據(jù)(最新推薦)
這篇文章主要介紹了vue3中如何使用ref和reactive定義和修改響應(yīng)式數(shù)據(jù),這里就是vue3中setup組合式api中如何定義響應(yīng)式數(shù)據(jù)并且修改賦值全部內(nèi)容,需要的朋友可以參考下2022-12-12

