快速理解Vue路由导航守卫

 更新时间:2021年12月29日 12:00:01   作者:前端老实人  
这篇文章主要介绍了快速理解Vue路由导航守卫,“导航”表示路由正在发生变化,vue-router 提供的导航守卫主要用来通过跳转或取消的方式守卫导航。有多种机会植入路由导航过程 中:全局的, 单个路由独享的, 或者组件级的,下面来快速来接具体内容吧

概念:

“导航”表示路由正在发生变化

vue-router 提供的导航守卫主要用来通过跳转或取消的方式守卫导航。有多种机会植入路由导航过程 中:全局的, 单个路由独享的, 或者组件级的。

导航守卫:包括全局导航守卫和局部导航守卫

一、全局守卫

vue-router全局有三个守卫

  • router.beforeEach :全局前置守卫,进入路由之前
  • router.beforeResolve :全局解析守卫,在beforeRouteEnter调用之后调用(不常用)
  • router.afterEach :全局后置钩子,进入路由之后

1.全局前置守卫

你可以使用 router.beforeEach 注册一个全局前置守卫:

const router = new VueRouter({ ... })
router.beforeEach((to, from, next) => {
// to和from都是路由实例
// to:即将跳转到的路由
// from:现在的要离开的路由
// next:函数
})

  • next: Function : 一定要调用该方法来 resolve 这个钩子。执行效果依赖 next 方法的调用参数。
  • next() : 进行管道中的下一个钩子。如果全部钩子执行完了,则导航的状态就是 confirmed (确认的)。
  • next(false) : 中断当前的导航。如果浏览器的 URL 改变了 (可能是用户手动或者浏览器后退按钮),那么 URL 地址会重置到 from 路由对应的地址。
  • next(‘/') 或者 next({ path: ‘/' }) : 跳转到一个不同的地址。当前的导航被中断,然后进行一个新的导航。你可以向 next 传递任意位置对象,且允许设置诸如 replace: true 、 name: ‘home' 之类的选项以及任何用在 router-link to proprouter.push 中的选项。
  • next(error) : (2.4.0+) 如果传入 next 的参数是一个 Error 实例,则导航会被终止且该错误会 被传递给 router.onError() 注册过的回调。

注意:如果是next(‘/') 或者 next({ path: ‘/' }),只要带了要放行的路径,那么前面必须有判断,在

什么时候给他放行,不然他会一直循环。

2.全局解析守卫

2.5.0 新增

// 全局解析守卫 
router.beforeResolve((to,from.next) => { })

在 2.5.0+ 你可以用 router.beforeResolve 注册一个全局守卫。这和 router.beforeEach 类似,区

别是在导航被确认之前,同时在所有组件内守卫和异步路由组件被解析之后,解析守卫就被调用。

3.全局后置钩子

你也可以注册全局后置钩子,然而和守卫不同的是,这些钩子不会接受 next 函数也不会改变导航本身:

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

因为:afterEach被调用时,路由已经跳转完成,所以不需要next函数

三、路由独享的守卫

如果不想在全局配置路由的话,可以为某些路由单独配置守卫

比如:mainpage页面单独配置守卫

{ 
path: '/mainpage', 
name: 'About', 
component: About, // 路由独享守卫 
beforeEnter:(to,from,next) => {
 if(from.name === '/mainpage/about'){ alert("这是从about来的") 
   }else{
 alert("这不是从about来的") 
   }next(); // 必须调用来进行下一步操作。否则是不会跳转的 
 }
} 
},

四、组件内的守卫

最后,你可以在路由组件内直接定义以下路由导航守卫:

  • beforeRouteEnter():进入路由前
  • beforeRouteUpdate():路由复用同一个组件时
  • beforeRouteLeave():离开当前路由时

在Product中举个例子:

// 全局解析守卫
router.beforeResolve((to,from.next) => {
})
// 全局后置钩子
router.afterEach((to,form) => {
})
{
path: '/mainpage',
name: 'About',
component: About,
// 路由独享守卫
beforeEnter:(to,from,next) => {
if(from.name === '/mainpage/about'){
alert("这是从about来的")
}else{
alert("这不是从about来的")
}
next(); // 必须调用来进行下一步操作。否则是不会跳转的
}
}
},
export default {
// 组件内守卫beforeRouteUpdate被触发的条件是:当前路由改变,但是该组件被复用的时候。
比如说:product/orders到product/cart这个路由,都复用了 Product.vue 这个组件,这个时候
beforeRouteUpdate就会被触发。可以获取到this实例。
一个完整的导航解析流程
// 因为这个钩子调用的时候,组件实例还没有被创建出来,因此获取不到this
beforeRouteEnter (to, from, next) {
console.log(to.name);
// 如果想获取到实例的话
// next(vm=>{
// // 这里的vm是组件的实例(this)
// });
next();
},
beforeRouteUpdate(to,from,next){
console.log(to.name, from.name);
next();
},
// 路由即将要离开的时候调用此方法
// 比如说,用户编辑了一个东西,但是还么有保存,这时候他要离开这个页面,就要提醒他一下,还没保
存,是否要离开
beforeRouteLeave (to, from, next) {
const leave = confirm("确定要离开吗?");
if(leave) next() // 离开
else next(false) // 不离开
},
}

  • beforeRouteUpdate被触发的条件是:当前路由改变,但是该组件被复用的时候。
  • 比如说:product/orders到product/cart这个路由,都复用了 Product.vue 这个组件,这个时候
  • beforeRouteUpdate就会被触发。可以获取到this实例。

五、一个完整的导航解析流程

  • 1、导航被触发。
  • 2、在失活的组件(即将离开的页面组件)里调用离开守卫。 beforeRouteLeave
  • 3、调用全局的 beforeEach 守卫。
  • 4、在重用的组件里调用 beforeRouteUpdate 守卫 (2.2+)。
  • 5、在路由配置里调用(路由独享的守卫) beforeEnter
  • 6、解析异步路由组件
  • 7、在被激活的组件(即将进入的页面组件)里调用 beforeRouteEnter
  • 8、调用全局的 beforeResolve 守卫 (2.5+)。
  • 9、导航被确认。
  • 10、调用全局的 afterEach 钩子。所有的钩子都触发完了。
  • 11、触发 DOM 更新。
  • 12、用创建好的实例调用 beforeRouteEnter 守卫中传给 next 的回调函数。

到此这篇关于快速理解Vue路由导航守卫的文章就介绍到这了,更多相关Vue路由导航守卫内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 基于vue3实现一个抽奖小项目

    基于vue3实现一个抽奖小项目

    在公司年会期间我做了个抽奖小项目,非常棒,今天把他分享到脚本之家平台,供大家学习参考,对vue3实现抽奖小项目感兴趣的朋友一起看看吧
    2023-01-01
  • vue3.0手动封装分页组件的方法

    vue3.0手动封装分页组件的方法

    这篇文章主要为大家详细介绍了vue3.0手动封装分页组件的方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-09-09
  • 使用 Vue3 实现文章目录功能

    使用 Vue3 实现文章目录功能

    本文给大家分享如何使用vue3实现文章目录功能,特色功能主要是自动高亮选中当前正在阅读的章节,自动展开当前正在阅读的章节的子标题,并隐藏其他章节的子标题,代码简单易懂,感兴趣的朋友跟随小编一起看看吧
    2022-03-03
  • Vue组件中prop属性使用说明实例代码详解

    Vue组件中prop属性使用说明实例代码详解

    这篇文章主要介绍了Vue组件中prop属性使用说明,非常不错具有一定的参考借鉴价值,需要的朋友可以参考下
    2018-05-05
  • Vue创建项目后没有webpack.config.js(vue.config.js)文件的解决

    Vue创建项目后没有webpack.config.js(vue.config.js)文件的解决

    这篇文章主要介绍了Vue创建项目后没有webpack.config.js(vue.config.js)文件的解决,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-01-01
  • vue制作加载更多功能的正确打开方式

    vue制作加载更多功能的正确打开方式

    这篇文章是一篇Vue.js的教程,目标在于用一种常见的业务场景——分页/无限加载,以及编写过程中自己的错误写法,分享给大家,帮助读者更好的理解Vue.js中的一些设计思想。
    2016-10-10
  • vue3如何使用element-plus的dialog

    vue3如何使用element-plus的dialog

    这篇文章主要介绍了vue3优雅的使用element-plus的dialog,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-04-04
  • vue2中,根据list的id进入对应的详情页并修改title方法

    vue2中,根据list的id进入对应的详情页并修改title方法

    今天小编就为大家分享一篇vue2中,根据list的id进入对应的详情页并修改title方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-08-08
  • Vue之Element级联选择器多选传值以及回显方式(树形结构)

    Vue之Element级联选择器多选传值以及回显方式(树形结构)

    这篇文章主要介绍了Vue之Element级联选择器多选传值以及回显方式(树形结构),具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-07-07
  • Vue之使用mockjs生成模拟数据案例详解

    Vue之使用mockjs生成模拟数据案例详解

    这篇文章主要介绍了Vue之使用mockjs生成模拟数据案例详解,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-09-09

最新评论