Vue使用路由鉤子攔截器beforeEach和afterEach監(jiān)聽路由
在路由跳轉(zhuǎn)的時候,我們需要一些權(quán)限判斷或者其他操作。這個時候就需要使用路由的鉤子函數(shù)。
定義:路由鉤子主要是給使用者在路由發(fā)生變化時進行一些特殊的處理而定義的函數(shù)。
總體來講vue里面提供了三大類鉤子,兩種函數(shù) 1、全局鉤子 2、某個路由的鉤子 3、組件內(nèi)鉤子
兩種函數(shù):
1. router.beforeEach(function(to,form,next){}) /*在跳轉(zhuǎn)之前執(zhí)行*/
2. router.afterEach(function(to,form)}{}) /*在跳轉(zhuǎn)之后判斷*/
全局鉤子函數(shù)
顧名思義,它是對全局有效的一個函數(shù)
// router.jsconst router = new Router({ routes: [ { path: ’/’, name: ’sideBar’, component: sideBar, children:[ { path:’/’, name:’sort’, component:sort }, { path:’/addNewSort’, name:’addNewSort’, component:addNewSort }, { path:’/notSend’, name:’notSend’, component:notSend }, { path:’/sended’, name:’sended’, component:sended }, } ]})router.beforeEach((to,from,next)=>{ // console.log('to:',to); // router即將進入的路由對象 // console.log('from:',from); // 當前導(dǎo)航即將離開的路由 // console.log('next:',next); // Function,進行管道中的一個鉤子,如果執(zhí)行完了,則導(dǎo)航的狀態(tài)就是 confirmed (確認的);否則為false,終止導(dǎo)航。 if(to.name==’notSend’){ next({ name:’sort’ }) return } next()})export default router
某個路由的鉤子函數(shù)
顧名思義,它是寫在某個路由里頭的函數(shù),本質(zhì)上跟組件內(nèi)函數(shù)沒有區(qū)別。
// router.jsconst router = new VueRouter({ routes: [ { path: ’/login’, component: Login, beforeEnter: (to, from, next) => { // ... }, beforeLeave: (to, from, next) => { // ... } } ]})
路由組件的鉤子
可以在路由組件內(nèi)直接定義以下路由導(dǎo)航鉤子
// *.vuebeforeRouteEnterbeforeRouteUpdate (2.2 新增)beforeRouteLeave
這里簡單說下鉤子函數(shù)的用法:它是和data,methods平級的。
beforeRouteLeave(to, from, next) { next()},beforeRouteEnter(to, from, next) { next()},beforeRouteUpdate(to, from, next) { // 用于相同路由組件的的參數(shù)更新 next()},data:{},method: {}
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. JavaWeb Servlet中url-pattern的使用2. jsp中sitemesh修改tagRule技術(shù)分享3. asp(vbscript)中自定義函數(shù)的默認參數(shù)實現(xiàn)代碼4. React優(yōu)雅的封裝SvgIcon組件示例5. 輕松學習XML教程6. php網(wǎng)絡(luò)安全中命令執(zhí)行漏洞的產(chǎn)生及本質(zhì)探究7. ASP刪除img標簽的style屬性只保留src的正則函數(shù)8. JSP servlet實現(xiàn)文件上傳下載和刪除9. ASP基礎(chǔ)知識VBScript基本元素講解10. 詳解瀏覽器的緩存機制
