vuevuevue

Vue 路由 导航守卫(全局守卫、路由独享守卫、组件内守卫)

2019-03-29  本文已影响188人  诺CIUM

一.全局守卫

1. router.beforeEach((to,from,next)=>{})

2. 回调函数中的参数,to:进入到哪个路由去,from:从哪个路由离开,next:函数,决定是否展示你要看到的路由页面。

3. 如下例:main.js中设置全局守卫

router.beforeEach((to,from,next)=>{
  if(to.path == '/login' || to.path == '/register'){
    next();
  }else{
    alert('您还没有登录,请先登录');
    next('/login');
  }
})

4. 全局后置钩子router.afterEach((to,from)=>{})

router.afterEach((to,from)=>{
  alert("after each");
})

5. 判断store.gettes.isLogin === false 是否登录

二.组件内的守卫

1. 到达这个组件时,beforeRouteEnter:(to,from,next)=>{}

<script>
export default {
    data(){
        return{
            name:"Arya"
        }
    },
    beforeRouteEnter:(to,from,next)=>{
        next(vm=>{
            alert("hello" + vm.name);
        })
    }
}
</script>

image image

2. 离开这个组件时,beforeRouteLeave:(to,from,next)=>{}

beforeRouteLeave:(to,from,next)=>{
        if(confirm("确定离开此页面吗?") == true){
            next();
        }else{
            next(false);
        }
    }

三.路由独享的守卫

1. beforeEnter:(to,from,next)=>{},用法与全局守卫一致。只是,将其写进其中一个路由对象中,只在这个路由下起作用。

上一篇下一篇

猜你喜欢

热点阅读