vue3 后台管理框架geeker admin 登录首页前的路由拦截

0 环境

1 文档

geeker admin官方文档

element-plus官方文档

vue router官方文档

2 需要的文件位置

  • src/routers/index.ts
  • src/views/login/components/LoginForm.vue

3 路由拦截

登录首页前的准备,动态路由的添加、清空 tabs、keepAlive 数据,前面这些工作完成后,很多时候会认为已经ok了,会直接跳转到首页,其实还漏了一步就是路由拦截。代码如下图:

首先获取了**useUserStore()**和 useAuthStore()useUserStore 主要是存的token和用户信息,useAuthStore主要是存权限相关数据。如下图所示:

1.NProgress 开始和2.动态设置标题 很容易理解,继续往下,3.判断是访问登陆页(to.path.toLocaleLowerCase() === LOGIN_URL) ,由于router.push 跳转到home/index ,那么to.path == home/index 。不等于LOGIN_URL ,继续往下,4.判断不在白名单中 ,继续往下走,5.若是token不存在,会跳转到登录页,因为在跳转到首页前,已经设有token ,那么继续往下,6.如果没有菜单列表,就重新请求菜单列表并添加动态路由 ,这里的判断也是很有必要的,因为动态路由是之后的核心,很多场景也会用到,比如刷新路由时,pinia动态路由没有做持久化,这里就会重新初始化动态路由,然后放行,跳转到目标path,当然你若是想路由持久化,那么需要在store中改动一下即可。这里我们的菜单列表是有的,到了7.将to.name存到 routerName中,做按钮权限筛选 ,然后放行,其实在跳转到home/index的过程中,比如会将动态路由和侧边栏菜单做一下处理等一系列操作,之后才真正的看到了欢迎你的界面。

4 流程图

流程图

5 总结

登录首页前的路由拦截,一个以防万一,还有就是做一些有必要的操作。这里了解即可。

相关推荐
用户2136610035721 小时前
Vue2组件化开发与父子通信
前端·vue.js
Momo__1 小时前
TypeScript satisfies 操作符——比 as 更安全的类型守门员
前端·typescript
用户2136610035721 小时前
Vue2事件系统与指令进阶
前端·vue.js
labixiong2 小时前
实现一个能跑的迷你版Promise(一)
前端·javascript·面试
Csvn3 小时前
`??` 和 `||` 搞混,线上用户头像全挂了
前端
kyriewen4 小时前
白宫前脚下了限制令,OpenAI 后脚就把 GPT-5.6 发了
前端·gpt·openai
用户40269244819085 小时前
CRMEB Pro 新增后台接口全链路:路由、权限、验证器、返回格式一次讲清
前端·后端
泉城老铁5 小时前
springboot+vue+ ffmpeg 实现视频的拉流播放
前端
逸铭5 小时前
Day 5:三栏布局——左账号 / 中聊天 / 右工具
vue.js·electron
PedroQue996 小时前
uni-router v1.8.0新增冷启动守卫补执行
前端·uni-app