這篇文章給大家分享的是有關(guān)Vue2.X中鉤子函數(shù)的示例分析的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
創(chuàng)新互聯(lián)網(wǎng)絡(luò)公司擁有10年的成都網(wǎng)站開發(fā)建設(shè)經(jīng)驗,成百上千客戶的共同信賴。提供成都網(wǎng)站設(shè)計、網(wǎng)站制作、網(wǎng)站開發(fā)、網(wǎng)站定制、賣友情鏈接、建網(wǎng)站、網(wǎng)站搭建、自適應(yīng)網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計師打造企業(yè)風(fēng)格,提供周到的售前咨詢和貼心的售后服務(wù)$route可以在子組件任何地方調(diào)用,代表當(dāng)前路由對象,這個屬性是只讀的,里面的屬性是 immutable(不可變) 的,不過你可以 watch(監(jiān)測變化) 它。
導(dǎo)航和鉤子函數(shù):
導(dǎo)航:路由正在發(fā)生改變 關(guān)鍵字:路由 變
鉤子函數(shù):在路由切換的不同階段調(diào)用不同的節(jié)點函數(shù)(鉤子函數(shù)在我看來也就是:某個節(jié)點和時機觸發(fā)的函數(shù))
兩者關(guān)系:
鉤子函數(shù) ---> 導(dǎo)航 :鉤子函數(shù) 主要用來攔截導(dǎo)航,讓它完成跳轉(zhuǎn)或取消,在導(dǎo)航的不同階段來執(zhí)行不同的函數(shù) ,最后鉤子函數(shù)的執(zhí)行結(jié)果會告訴導(dǎo)航怎么做。。
導(dǎo)航 ---> 鉤子函數(shù) :導(dǎo)航在所有鉤子 resolve 完之前一直處于 等待中,等待鉤子函數(shù)告訴它下一步該怎么做。用next()來指定。
全局鉤子函數(shù)之 全局的beforeEach鉤子:
例子: 在每次發(fā)生路由導(dǎo)航是最開始先檢測用戶是否登錄
router.beforeEach(({meta, path}, from, next) => { const {auth = true} = meta // meta代表的是to中的meta對象,path代表的是to中的path對象 var isLogin = Boolean(store.state.user.id) // true用戶已登錄, false用戶未登錄 if (auth && !isLogin && path !== '/login') { // auth 代表需要通過用戶身份驗證,默認為true,代表需要被驗證, false為不用檢驗 return next({ path: '/login' }) // 跳轉(zhuǎn)到login頁面 } next() // 進行下一個鉤子函數(shù) })
先說這個beforeEach的鉤子函數(shù),它是一個全局的before 鉤子函數(shù),(before each)意思是在 每次每一個路由改變的時候都得執(zhí)行一遍。
它的三個參數(shù):
to: (Route路由對象) 即將要進入的目標(biāo) 路由對象 to對象下面的屬性: path params query hash fullPath matched name meta(在matched下,但是本例可以直接用)
from: (Route路由對象) 當(dāng)前導(dǎo)航正要離開的路由
next: (Function函數(shù)) 一定要調(diào)用該方法來 resolve 這個鉤子。 調(diào)用方法:next(參數(shù)或者空) ***必須調(diào)用
next(無參數(shù)的時候): 進行管道中的下一個鉤子,如果走到最后一個鉤子函數(shù),那么 導(dǎo)航的狀態(tài)就是 confirmed (確認的)
next('/') 或者 next({ path: '/' }):跳轉(zhuǎn)到一個不同的地址。當(dāng)前的導(dǎo)航被中斷,然后進行一個新的導(dǎo)航。
全局鉤子函數(shù)之 全局的afterEach鉤子:
after 鉤子沒有 next 方法,不能改變導(dǎo)航,代表已經(jīng)確定好了導(dǎo)航怎么去執(zhí)行后,附帶的一個執(zhí)行鉤子函數(shù)
組件內(nèi)的鉤子函數(shù):( beforeRouteEnter 和 beforeRouteLeave 再加一個 watch函數(shù) )
vue2.X的組件內(nèi)鉤子函數(shù)比vue1.X減少了許多。。
https://github.com/vuejs/vue-router/blob/43183911dedfbb30ebacccf2d76ced74d998448a/examples/navigation-guards/app.js#L49
使用組件自身的生命周期鉤子函數(shù)來替代 activate 和 deactivate
在 $router 上使用 watcher 來響應(yīng)路由改變
canActivate 可以被 router 的配置中的 beforeEnter 中實現(xiàn)
canDeactivate 已經(jīng)被 beforeRouteLeave 取代, 后者在一個組件的根級定義中指定。這個鉤子函數(shù)在調(diào)用時是將組件的實例作為其上下文的。
canReuse 已經(jīng)被移除,因其容易混淆且很少被用到。
用ajax獲取數(shù)據(jù)的data(to, from, next) 鉤子用組件內(nèi) beforeRouteEnter (to, from, next)來替代
先來解釋下vue1.X中的組件內(nèi)鉤子函數(shù):
組件的鉤子函數(shù)一共6個:
data:可以設(shè)置組件的data
activate:激活組件
deactivate:禁用組件
canActivate:組件是否可以被激活
canDeactivate:組件是否可以被禁用
canReuse:組件是否可以被重用
vue-router1.X中 每個切換鉤子函數(shù)都會接受一個 transition 對象作為參數(shù),參數(shù)下有5個屬性/方法 to from next() abort([reason]) redirect(path)
vue-router2.X中 其中后三個都歸到next()函數(shù)里了 , 所以next()函數(shù)改為3個直接的參數(shù) ( to from next() )
例子:
路由的切換分為三個階段:可重用階段,驗證階段和激活階段
以 home/news 切換到 home/message 為例來描述各個階段
可以重用組件Home,因為重新渲染后,組件Home依然保持不變。
確保切換效果有效——也就是說,為保證切換中涉及的所有組件都能按照期望的那樣被停用/激活
需要停用并移除組件News,啟用并激活組件Message。
此階段對應(yīng)鉤子函數(shù)的調(diào)用順序和驗證階段相同,其目的是在組件切換真正執(zhí)行之前提供一個進行清理和準(zhǔn)備的機會。
界面的更新會等到所有受影響組件的 deactivate 和 activate 鉤子函數(shù)執(zhí)行之后才進行。
data 這個鉤子函數(shù)會在 activate 之后被調(diào)用,或者當(dāng)前組件組件可以重用時也會被調(diào)用。
通過上述vue-router1.x,那么2.x的執(zhí)行順序可以如以下方式理解:
鉤子的執(zhí)行順序就是:1、最開始beforeEach鉤子,
2、然后舊的組件是否能重用canReuse,不重用的是否能canDeactivate,再看新的組件是否canActivate,再后把不能重用的能銷毀的給deactivate
3、這樣舊的不重用的組件就結(jié)束了它的生命周期了,所以這時候在結(jié)束生命周期之前執(zhí)行調(diào)用afterEach函數(shù)
4、新組建開始的話先是activate,然后再是data,如果重用的話就沒有銷毀,所以一直在activate中,只是執(zhí)行data鉤子。
那么這樣的鉤子函數(shù)對應(yīng)給vue2.x會是怎樣的呢???(--------待驗證-------)
1、最先執(zhí)行的是 beforeEach鉤子,所有路由開始的時候最先執(zhí)行。
2、然后就是 router 的配置中的beforeEnter。
3、接下來是 路由的 beforeRouteEnter ----- 然后是組件自身的生命周期 ------ 路由 beforeRouteLeave
beforeRouteEnter (to, from, next) {} 與 beforeRouteLeave不再是組件中route配置下的對象了,他們和data處于同級別的地位。
可以看出: 新設(shè)計的路由 淡化了組件自身跟著路由生命周期變化而變化,而是依賴組件自身的生命周期,只有兩個簡單的 路由級別的鉤子 beforeRouteEnter beforeRouteLeave
那么接下來:
ajax調(diào)用時機:相對于組件來說的,而且應(yīng)該是在路由進入之前開始準(zhǔn)備的 所以beforeRouteEnter是調(diào)用ajax的時機。
watch這一函數(shù)可以監(jiān)聽路由$route變化。
beforeRouteLeave在組件的生命周期完成后,且舊路由即將切換走,新路由beforeEach的時機執(zhí)行。
watch的使用時機:
當(dāng)使用路由參數(shù)時,例如從 /user/foo 導(dǎo)航到 user/bar,原來的組件實例會被復(fù)用。因為兩個路由都渲染同個組件,比起銷毀再創(chuàng)建,復(fù)用則顯得更加高效。
不過,這也意味著 組件的生命周期鉤子不會再被調(diào)用。
復(fù)用組件時,想對路由參數(shù)的變化作出響應(yīng)的話,你可以簡單地 watch(監(jiān)測變化) $route 對象:
const User = { template: '...', 1、watch: { '$route' (to, from) { // 對路由變化作出響應(yīng)... } } 2、watch: { '$route': 'fetchData' // 如果路由有變化,會再次執(zhí)行fetchData方法 },
感謝各位的閱讀!關(guān)于“Vue2.X中鉤子函數(shù)的示例分析”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)建站muchs.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機、免備案服務(wù)器”等云主機租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。
當(dāng)前標(biāo)題:Vue2.X中鉤子函數(shù)的示例分析-創(chuàng)新互聯(lián)
URL地址:http://muchs.cn/article26/ioccg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站策劃、網(wǎng)站設(shè)計、關(guān)鍵詞優(yōu)化、靜態(tài)網(wǎng)站、定制開發(fā)、軟件開發(fā)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容