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 总结

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

相关推荐
道友可好14 小时前
3 个人,100 万行代码,一行都没人写:OpenAI 的 Harness Engineering 实验
前端·人工智能·后端
W_LuYi18514 小时前
Tauri + Rust + Vue 3 打造极速轻量桌面应用
java·开发语言·vue.js·rust
winfredzhang14 小时前
用 Node.js + SQLite + 原生前端写一个本地情绪急救 Web App:情绪降落伞 Mood Parachute
前端·sqlite·node.js·express·情绪管理
qq43569470114 小时前
Vue03
javascript·vue.js
樱花的浪漫14 小时前
Typescript、Zod基础
前端·javascript·人工智能·语言模型·自然语言处理·typescript
Bigger15 小时前
记一次坑爹的 Cloudflare Pages 部署:Failed to load module script 是怎么把我的 SPA 搞挂的
前端·ci/cd·浏览器
用户5495916575015 小时前
TinyVue Tree树形控件完全指南
vue.js
竹林81815 小时前
监听智能合约事件,我用 wagmi v2 踩了三天坑,终于找到了稳定方案
前端·javascript
星栈15 小时前
Makepad 界面怎么做得更像产品,而不是示例
前端·rust
用户8524950718415 小时前
Bun 到底是什么?一个比 Node.js "更快更香"的 JS 运行时
javascript·程序员