vue路由守卫哪几种?


本文摘自PHP中文网,作者青灯夜游,侵删。

vue路由守卫有三种,分别为:1、全局守卫“router.beforeEach”;2、组件内的守卫“beforeRouteEnter”;3、路由独享守卫“beforeEnter”。

vue中路由守卫一共有三种,一个全局路由守卫,一个是组件内路由守卫,一个是路由独享守卫。

所谓的路由守卫可以简单的理解为一座房子的门口的保安,想要进入这个房子就必须通过保安的检查,要告诉路由守卫你从哪里来?总不能随便陌生人就给放进去?要到哪里去?然后保安再告诉你下一步该怎么做?如果你的确是这个房子主人允许进入的人,那就让你进入,否则就要打电话给房子主人,跟房主商量(登录注册),给你权限。

1

2

// 通过这个匹配判断是否有该权限或要求,这个一般作为页面权限设置,比如哪些页面需要登录才能进入,哪些不需要

to.matched.some(res => res.meta.requireAuth)

一.全局守卫

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

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

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

  • 在main.js中,有一个路由实例化对象router。在main.js中设置守卫已是全局守卫。
  • 如下,判断to.path当前将要进入的路径是否为登录或注册,如果是就执行next(),展示当前界面。如果不是,就弹出alert,然后移至登录界面。
  • 这样就可实现,用户在未登录状态下,展示的一直是登录界面。

1

2

3

4

5

6

7

8

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

  if(to.path == '/login' || to.path == '/register'){

    next();

  }else{

    alert('您还没有登录,请先登录');

    next('/login');

  }

})

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

  • 只有两个参数,to:进入到哪个路由去,from:从哪个路由离。
  • 如下,每次切换路由时,都会弹出alert,点击确定后,展示当前页面。

1

2

3

router.afterEach((to,from)=>{

  alert("after each");

})

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

二.组件内的守卫

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

  • 在Admin.vue文件中,点击转到admin路由时,执行beforeRouteEnter函数
  • to,from参数与上面使用方法一致。next回调函数略有不同。
  • 如下例,data 组件内守卫有特殊情况,如果我们直接以
    beforeRouteEnter:(to,from,next)=>{ alert("hello" + this.name);}进行访问admin页面,会发现alert输出hello undefined。这是因为,现在访问不到我们的data属性,执行顺序是不一致,这与的声明周期有关。在执行完之前,data数据还未渲染。所以这里,next()会给一个对应的回调,帮助完成。

1

2

3

4

5

6

7

8

9

10

11

12

13

14

<script>

export default {

    data(){

        return{

            name:"Arya"

        }

    },

    beforeRouteEnter:(to,from,next)=>{

        next(vm=>{

            alert("hello" + vm.name);

        })

    }

}

</script>

1.webp.jpg

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

  • 点击其他组件时,判断是否确认离开。确认执行next();取消执行next(false),留在当前页面。

1

2

3

4

5

6

7

beforeRouteLeave:(to,from,next)=>{

        if(confirm("确定离开此页面吗?") == true){

            next();

        }else{

            next(false);

        }

    }

三.路由独享的守卫

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

2.webp.jpg

相关推荐:

2020年前端vue面试题大汇总(附答案)

vue教程推荐:2020最新的5个vue.js视频教程精选

更多编程相关知识,请访问:编程学习课程!!

以上就是vue路由守卫哪几种?的详细内容,更多文章请关注木庄网络博客

相关阅读 >>

一招搞定vue常用指令

vue $on是什么意思

vue中怎么导出excel文件?

.js文件中怎么引用vue

vue-loader是什么?

如何解决vue $index报错问题

vuex中常用知识点(总结)

vue和react属于js库吗

vue1.0与2.0有什么区别

vue有react native吗

更多相关阅读请进入《vue》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...