vue开发:组件内的导航守卫
程序员文章站
2022-06-28 19:00:49
故事背景面试但凡问到vue框架,vue-router是逃不掉的~vue为我们提供了全局守卫、路由独享的守卫、组件内的守卫,详情戳这vue导航守卫卤煮借项目里实际的应用场景来讲一下组件内的导航守卫,顺便记录一下小坑~应用场景当页面返回上一页的时候,拦截路由,提示用户是否确定离开当前页面,上图~代码实现组件内的导航守卫:beforeRouteEnter和beforeRouteLeave两个钩子函数,拦截跳转用到的是beforeRouteLeave,上图~这里有个小坑,因为return写习惯了...
故事背景
面试但凡问到vue框架,vue-router是逃不掉的~
vue为我们提供了全局守卫、路由独享的守卫、组件内的守卫,详情戳这vue导航守卫
卤煮借项目里实际的应用场景来讲一下组件内的导航守卫,顺便记录一下小坑~
应用场景
当页面返回上一页的时候,拦截路由,提示用户是否确定离开当前页面,上图~
代码实现
组件内的导航守卫:beforeRouteEnter和beforeRouteLeave两个钩子函数,拦截跳转用到的是beforeRouteLeave,上图~
这里有个小坑,因为return写习惯了,以为在前面写了return下面就不执行了,实则不然,next在这里执行了,正确的写法如下:
next()传入true执行跳转,传入false则实现拦截,留在当前页。它也可以接收一个对象,例如:
next({
path: '/login', params: { // 你想传的参数 }
});
注意!!!
在页面A,用户点击了返回,提示框弹出并且用户点击了确定离开,然后成功返回上一页。当用户通过浏览器导航栏进行返回前进,此时我们组件实例中的isGoback(此时isGoback为true)不会发生改变,再次返回就不会弹出提示框了哦。所以最稳妥的解决方法就是在进入页面的时候重置一下这个变量,这时候就用到beforeRouteEnter这个钩子函数了~
那么问题来了,官方说beforeRouteEnter钩子里面是获取不到this的,这可怎么搞,上图~
以上利用组件内的导航守卫,完美解决了路由拦截,实现我们上面提到的应用场景,记得勿踩坑~
本文地址:https://blog.csdn.net/yman_pro/article/details/107372970
推荐阅读
-
vue学习指南:第十四篇(详细) - Vue的 路由 第四篇 ( 路由的导航守卫 )
-
Vue递归组件+Vuex开发树形组件Tree--递归组件的简单实现
-
[Vue 牛刀小试]:第十四章 - 编程式导航与实现组件与 Vue Router 之间的解耦
-
使用vue封装一个tab栏切换的左侧导航栏的公共组件
-
vue组件从开发到发布的实现步骤
-
Vue.js的复用组件开发流程完整记录
-
使用Vue开发动态刷新Echarts组件的教程详解
-
vue-router导航守卫(router.beforeEach())的使用
-
详解Vue组件插槽的使用以及调用组件内的方法
-
vue路由导航守卫和请求拦截以及基于node的token认证的方法