国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

基于Vue2.X的路由和鉤子函數詳解

2019-11-19 14:22:38
字體:
來源:轉載
供稿:網友

最近上班有些忙,好久沒有更新文章,也沒學習新的東西。

今天來說說這個路由鉤子吧。

導航和鉤子函數:

導航:路由正在發生改變 關鍵字:路由 變

鉤子函數:在路由切換的不同階段調用不同的節點函數(鉤子函數在我看來也就是:某個節點和時機觸發的函數)。

鉤子函數 主要用來攔截導航,讓它完成跳轉或取消,在導航的不同階段來執行不同的函數 ,最后鉤子函數的執行結果會告訴導航怎么做。。

導航在所有鉤子 resolve 完之前一直處于 等待中,等待鉤子函數告訴它下一步該怎么做。用next()來指定。

我來給大家舉個登陸的例子

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' }) // 跳轉到login頁面   }     next() // 進行下一個鉤子函數 }) 

先說這個beforeEach的鉤子函數,它是一個全局的before 鉤子函數, (before each)意思是在 每次每一個路由改變的時候都得執行一遍。

它的三個參數:

to: (Route路由對象) 即將要進入的目標 路由對象 to對象下面的屬性: path params query hash fullPath matched name meta(在matched下,但是本例可以直接用)

from: (Route路由對象) 當前導航正要離開的路由

next: (Function函數) 一定要調用該方法來 resolve 這個鉤子。 調用方法:next(參數或者空) ***必須調用

next(無參數的時候): 進行管道中的下一個鉤子,如果走到最后一個鉤子函數,那么 導航的狀態就是 confirmed (確認的)

next('/') 或者 next({ path: '/' }): 跳轉到一個不同的地址。當前的導航被中斷,然后進行一個新的導航。

全局鉤子函數之 全局的afterEach鉤子:

after 鉤子沒有 next 方法,不能改變導航,代表已經確定好了導航怎么去執行后,附帶的一個執行鉤子函數

組件內的鉤子函數:( beforeRouteEnter 和 beforeRouteLeave 再加一個 watch函數 )

vue2.X的組件內鉤子函數比vue1.X減少了許多。。

使用組件自身的生命周期鉤子函數來替代 activate 和 deactivate

在 $router 上使用 watcher 來響應路由改變

canActivate 可以被 router 的配置中的 beforeEnter 中實現

canDeactivate 已經被 beforeRouteLeave 取代, 后者在一個組件的根級定義中指定。這個鉤子函數在調用時是將組件的實例作為其上下文的。

canReuse 已經被移除,因其容易混淆且很少被用到。

用ajax獲取數據的data(to, from, next) 鉤子用組件內 beforeRouteEnter (to, from, next)來替代

以上這篇基于Vue2.X的路由和鉤子函數詳解就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 洛隆县| 平江县| 德江县| 汝南县| 焦作市| 吴川市| 交城县| 福安市| 龙海市| 大足县| 绿春县| 泸州市| 兴国县| 茂名市| 密山市| 聂拉木县| 泽州县| 积石山| 清新县| 武乡县| 增城市| 夏河县| 望江县| 读书| 龙游县| 来宾市| 青冈县| 广安市| 台北县| 通榆县| 福建省| 贡觉县| 莱阳市| 佛山市| 普格县| 崇文区| 兴安盟| 方正县| 建阳市| 兴安盟| 通渭县|