路由守卫是什么,vue-router如何实现路由守卫

Admin 2022-10-19 群英技术资讯 363 次浏览

这篇文章给大家分享的是“路由守卫是什么,vue-router如何实现路由守卫”,对大家学习和理解有一定的参考价值和帮助,有这方面学习需要的朋友,接下来就跟随小编一起学习一下吧。

概述

何为路由守卫?路由守卫有点类似于ajax的请求拦截器,就是请求发送之前先给你拦截住做一些事情之后再去发送请求,同样这里的路由守卫意思差不多;简单理解为就是你在进路由之前,首先把你拦住,对你进行检查;这是不是有点中学门口的保安?进来之前拦住,有学生证就进,没有学生证就不让进;当然,路由守卫不仅仅只是在你进入之前拦住你,还有其他的钩子函数进行其他操作;

vue-router一共给我们提供了三大类钩子函数来实现路由守卫:

1、全局钩子函数(beforeEach、afterEach)

2、路由独享的钩子函数(beforeEnter)

3、组件内钩子函数(beforeRouterEnter、beforeRouterUpdate、beforeRouterLeave)

首先我们先来看一下全局钩子函数:

全局钩子函数

beforeEach:

beforeEach一共接收三个参数,分别是to、from、next;to:即将进入的路由对象;from:正要离开的路由对象;next:路由的控制参数;

next一共有四种调用方式:

next():一切正常调用这个方法进入下一个钩子;

next(false):取消路由导航,这时的url显示的是正要离开的路由地址;

next('/login'):当前路由被终止,进入一个新的路由导航(路由地址可以自由指定)

next(error):路由导航终止并且错误会被传递到router.onError()注册过的回调中;

我们一般是用全局钩子来控制权限,像什么进页面没有登录就跳登录页,需要用户达到什么级别才能访问当前页面都是属于页面权限控制,都是可以通过beforeEach钩子函数来实现:

main.js(全局钩子函数我们一般是在main.js中进行书写):

// 进入路由前方法勾子 router.beforeEach((to, from, next) => {    console.log(to, '前置第一个参数' )    console.log(from, '前置第二个参数' )    console.log(next, '前置第三个参数' )    /      to 目标路由      from 源路由      next 跳转到下一个路由    */ //这里暂时用local、storange来简单模拟验证权限    if (window.localstorange.getItem( "token" )) {      // 如果存在,则直接跳转到对应路由       next();    } else {      // 如果不存在,则跳转到登录页      next( '/login' );    } });

AfterEach:

AfterEach和beforeEach一样都是属于全局守卫钩子,都是在main.js中进行调用;其中AfterEach比beforeEach少一个next参数;

from:正要离开的路由对象;

afterEach()我们一般用来重置页面滚动条位置:

假如我们有一个页面很长,滚动后其中的某个位置后跳转,这时新的页面的滚动条位置就会在上一个页面停留的位置;这个时候我们就可以利用afterEach进行重置:

  //全局路由改变后钩子 router.afterEach((to, from) => {    //将滚动条恢复到最顶端    window.scrollTo(0, 0); })

路由独享的钩子函数

beforeEneter:

路由独享顾名思义就是指定的路由才有这些钩子函数,通常这类路由独享的钩子函数我们是在路由配置文件中进行配置,只能设置改变前的钩子,不能设置改变后的钩子


const router= new VueRouter({      routes }); const routes=[      {          path: '/page1' ,          component:page1,          children: [              {                  path: "phone" ,                  component: phone              },              {                  path: "computer" ,                  component: computer              },          ], //路由独享的钩子函数          beforeEnter:(to,from,next)=>{              console.log(to);              console.log(from);              next( false );          }      },

上述代码理解为只有进入/page1才会触发beforeEnter这个钩子,如果进入其他页面,是不触发的;

组件内的钩子函数

beforeRouteEnter(to,from,next):

在路由进入前调用,因为此时的vue实例还没有创建,所以beforeEnter是唯一一个不能使用this的钩子函数;

to:即将要进入的路由对象;

from:正要离开的路由对象;

next:路由控制参数

beforeRouteUpdate(to,from,next):

在路由发生修改的时候进行调用,比如我们上一篇文章讲到的动态路由传参,这种情况我们的beforeRouteUpdate也是会被调用的;

 to:即将要进入的路由对象;

from:正要离开的路由对象;

next:路由控制参数;

beforeRouteLeave(to,from,next):

在路由离开该组件时调用;

to:即将要进入的路由对象;

from:正要离开的路由对象;

next:路由控制参数

注意:beforeRouteEnter因为触发的时候vue实例还没有创建,所以这个钩子函数中不能使用this,而beforeRouteUpdate和beforeRouteLeave都是可以访问到实例的,因为当这两个函数触发的时候实例都已经被创建了;

当调用组件内的钩子函数的时候,我们通常是在组件内部进行调用,举个例子:


<template>      <div>          <h1 id= "h1" >主页</h1>          <p>              <router-link to= "/page1/phone" >手机</router-link>              <router-link to= "/page1/computer" >电脑</router-link>          </p>          <router-view></router-view>      </div> </template> <script>      export default {      //路由进入前调用    beforeRouteEnter (to, from, next) {      window.document.title  = "欢迎" ;      next();    },      //路由修改时调用    beforeRouteUpdate(to,from,next){      },     //路由离开时调用    beforeRouteLeave(to,from,next){      },          data () {              return {                  msg: "我是page1组件"              }          },      } </script>


以上就是关于“路由守卫是什么,vue-router如何实现路由守卫”的相关知识,感谢各位的阅读,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注群英网络,小编每天都会为大家更新不同的知识。
群英智防CDN,智能加速解决方案
标签: 路由守卫

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。

猜你喜欢

成为群英会员,开启智能安全云计算之旅

立即注册
专业资深工程师驻守
7X24小时快速响应
一站式无忧技术支持
免费备案服务
免费拨打  400-678-4567
免费拨打  400-678-4567 免费拨打 400-678-4567 或 0668-2555555
在线客服
微信公众号
返回顶部
返回顶部 返回顶部
在线客服
在线客服