我的编程空间,编程开发者的网络收藏夹
学习永远不晚

vue中的导航守卫使用及说明

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

vue中的导航守卫使用及说明

导航守卫

  • 作用:对路由进行权限控制
  • 分类:全局守卫、独享守卫、组件内守卫

全局守卫

const router = new VueRouter({
  routes: [
    {
      path: '/home',
      component: Home,
      meta: { isAuth: false },	// 不需要进行权限控制
    },
     {
      path: '/user',
      component: User,
      meta: { isAuth: true },	// 需要进行权限控制
    },
  ]
})
// 全局前置守卫:初始化时执行/每次路由切换前执行
router.beforeEach((to,from,next) => {
  if(to.meta.isAuth) {  // 判断当前路由是否需要进行权限控制(在需要进行权限控制的路由中配置isAuth属性)
    if(localStorage.getItem('xxx') === 'xxx') { // 权限控制的具体规则
      next();   // 放行
    }else {
      ...
    }
  } else {  // 当前路由不需要进行权限控制
    next(); // 直接放行
  }
})
// 全局后置守卫:初始化时执行,每次路由切换后执行
router.afterEach((to,from) => {
  if(to.meta.title) {
    document.title = to.meta.title; // 修改网页的title
  }else {
    document.title = 'xxx';
  }
})

独享守卫

加在某个路由的配置中

beforeEnter((to,from,next) => {
  if(to.meta.isAuth) {  // 判断当前路由是否需要进行权限控制(在需要进行权限控制的路由中配置isAuth属性)
    if(localStorage.getItem('xxx') === 'xxx') { // 权限控制的具体规则
      next();   // 放行
    }else {
      ...
    }
  } else {  // 当前路由不需要进行权限控制
    next(); // 直接放行
  }
})

组件内守卫

// 进入守卫,通过路由规则,进入该组件时被调用
beforeRouteEnter(to,from,next){
  ...
}
// 当前路由改变,但是该组件被复用时调用
// 举例来说,对于一个带有动态参数的路径 /foo/:id,在 /foo/1 和 /foo/2 之间跳转的时候,
// 由于会渲染同样的 Foo 组件,组件实例会被复用。而这个钩子就会被调用
beforeRouteUpdate(to,from,next{
  ...
}
// 离开守卫,通过路由规则,离开该组件时被调用
beforeRouteLeave(to,from,next){
  ...
}

vue导航守卫有哪些

路由的钩子函数有六个

  • 全局的路由钩子函数:beforeEach、afterEach
  • 单个路由的钩子函数:beforeEnter
  • 组件内路由钩子函数:beforeRouteEnter、beforeRouteUpdate、beforeRouteLeave

全局路由钩子函数

1、全局前置守卫: beforeEach(to, from, next)

router.beforeEach: 在每次每一个路由改变的时候都会执行一遍

  • to:将要进入的路由对象
  • from: 当前正要离开的路由对象
  • next

next(),进入下一个路由,必须调用,不然不会跳转

next(false): 中断当前的导航。如果浏览器的 URL 改变了 (可能是用户手动或者浏览器后退按钮),那么 URL 地址会重置到 from 路由对应的地址。

next(’/’) 或者 next({ paht:’/’}):跳转到一个不同的地址。当前的导航会被中断,然后进行一个新的导航。可传递的参数可以是 router-link 标签中的 to 属性参数或 router.push 中的选项

应用场景:可进行一些页面跳转前处理,例如判断需要登录的页面进行拦截,做登录跳转, 还有管理员权限判断。

2、全局后置守卫:afterEach(to, from)

router.afterEach: 和 beforeEach 相反,它是在路由跳转完成后触发,它发生在 beforeEach 之后 beforeRouteEnter(组件内守卫) 之前, 因为是跳转完成后触发,所以没有 next 参数。

路由内的钩子函数

路由独享守卫:beforeEnter(to, from, next)

和 beforeEach 完全相同,如果两个都设置了,beforeEnter 则在 beforeEach 之后紧随执行。在路由配置上直接定义 beforeEnter 守卫

组件内的钩子函数

是指在组件内执行的钩子函数,类似于组件内的生命周期

  • 组件前置守卫 beforeRouteEnter: 该钩子在全局守卫 beforeEach 和独享守卫 beforeEnter 之后。
  • 组件更新守卫 beforeRouteUpdate:在当前路由改变时,并且该组件被复用时调用。
  • 组件离开守卫 beforeRouteLeave:导航离开该组件的对应路由时调用
const Foo = {
  template: `...`,
  beforeRouteEnter (to, from, next) {
    // 在渲染该组件的对应路由被 confirm 前调用
    // 不!能!获取组件实例 `this`
    // 因为当钩子执行前,组件实例还没被创建
  },
  beforeRouteUpdate (to, from, next) {
    // 在当前路由改变,但是该组件被复用时调用
    // 举例来说,对于一个带有动态参数的路径 /foo/:id,在 /foo/1 和 /foo/2 之间跳转的时候,
    // 由于会渲染同样的 Foo 组件,因此组件实例会被复用。而这个钩子就会在这个情况下被调用。
    // 可以访问组件实例 `this`
  },
  beforeRouteLeave (to, from, next) {
    // 导航离开该组件的对应路由时调用
    // 可以访问组件实例 `this`
  }

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

vue中的导航守卫使用及说明

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

vue中的导航守卫使用及说明

这篇文章主要介绍了vue中的导航守卫使用及说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2023-01-28

Vue导航守卫怎么使用

这篇文章主要介绍“Vue导航守卫怎么使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Vue导航守卫怎么使用”文章能帮助大家解决问题。守卫参数to: 即将要进入的目标路由from: 当前导航即将要离
2023-07-06

vue-router的导航守卫怎么使用

这篇文章主要介绍了vue-router的导航守卫怎么使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇vue-router的导航守卫怎么使用文章都会有所收获,下面我们一起来看看吧。前言在浏览器中点击链接实现导航
2023-07-04

Vue导航守卫使用教程详解

这篇文章主要介绍了Vue导航守卫使用教程,可以向任意给定的导航守卫传递next,但是next的使用过程容易出错,需要确保next在任何给定的导航守卫中都被严格调用一次
2023-05-15

vue-router的导航守卫使用最新讲解

这篇文章主要介绍了vue-router的导航守卫使用讲解,vue-router提供了许多编程式导航的API,其中最常见的导航API有很多种,本文给大家详细讲解,需要的朋友可以参考下
2022-12-16

Vue中的路由导航守卫导航解析流程

这篇文章主要介绍了Vue中的路由导航守卫导航解析流程,正如其名,vue-router提供的导航守卫主要用来通过跳转或取消的方式守卫导航。这里有很多方式植入路由导航中:全局的,单个路由独享的,或者组件级的
2023-05-16

Vue3中的导航守卫如何使用

一、什么是导航守卫?正如其名,vue-router提供的导航守卫主要用来通过跳转或取消的方式守卫导航。这里有很多方式植入路由导航中:全局的,单个路由独享的,或者组件级的。查看以下情形:点击主页链接时,默认情况下可直接进入指定界面,如图,但是问题是该跳转的界面是需要用户登录后方可访问的可设置导航守卫来检测用户是否登录,如果已登录,则进入后台页,如果未登录,则强制进入登录页,如图二、导航守卫有哪几种?1、全局守卫(3个)全局前置守卫每次发生路由的导航跳转时,都会触发全局前置守卫,因此,在全局前置守卫
2023-05-16

Vue声明式导航与编程式导航及导航守卫和axios拦截器全面详细讲解

这篇文章主要介绍了Vue声明式导航与编程式导航及导航守卫和axios拦截器,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习吧
2023-01-14

Vue3中导航守卫的基本使用方法

这篇文章主要给大家介绍了关于Vue3中导航守卫的基本使用方法,正如其名vue-router 提供的导航守卫主要用来通过跳转或取消的方式守卫导航,下面需要的朋友可以参考下
2023-03-09

vue-jsonp的使用及说明

这篇文章主要介绍了vue-jsonp的使用及说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2022-12-08

vue中定时器setInterval的使用及说明

这篇文章主要介绍了vue中定时器setInterval的使用及说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2023-03-02

vue中关于$emit和$on的使用及说明

这篇文章主要介绍了vue中关于$emit和$on的使用及说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2022-11-13

vue中letthat=this的作用及说明

这篇文章主要介绍了vue中letthat=this的作用及说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2022-11-13

vue之Vue.use的使用场景及说明

这篇文章主要介绍了vue之Vue.use的使用场景,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2022-12-08

编程热搜

目录