news 2026/4/16 9:55:47

前端路由设置

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
前端路由设置

构建一个健壮的前端路由系统,不仅仅是把页面配置进去,更要考虑层级结构、权限控制、用户体验(重定向)以及异常兜底(404)。

一、路由分类(层级结构)

1. 第一层(顶层)

  • 区分“无需登录页面”(如登录页)和“需登录业务页”(如后台主界面)
  • 示例配置:
    {path:"/login",component:"LoginPage"},

2. 第二层(业务层)

  • 加载全局 Layout(侧边栏、Header),并进行权限校验
  • 示例配置:
    {path:"/",component:"@/widgets/MainLayout",routes:[{path:"/",redirect:"/dashboard"},{path:"/dashboard",component:"DashboardPage",wrappers:["@/wrappers/auth"],},// 其他业务页面...]}
  • 路由守卫(auth Wrapper)实现:
    import{Navigate,Outlet,useLocation}from"umi";import{isUserLoggedIn}from"@/shared/utils/auth";/** * 路由守卫(第一道防线) * 拦截没有 Token 的用户,并重定向到登录页,传递 reason=no_auth */exportdefault()=>{constlocation=useLocation();constisLogin=isUserLoggedIn();if(isLogin){return<Outlet/>;}else{// 构造目标 URL// 1. redirect: 登录成功后要跳回的地方// 2. reason=no_auth: 告诉登录页,这是因为没登录被拦截过来的constcurrentPath=encodeURIComponent(location.pathname+location.search);consttargetUrl=`/login?redirect=${currentPath}&reason=no_auth`;return<Navigate to={targetUrl}replace/>;}};

3. 第三层(功能层)

  • 具体的业务页面、重定向规则、内部 404
  • 示例配置:
    {path:"*",component:"404"},

二、路由书写顺序

  • 路由匹配是“从上到下”的 (Order Matters),路由器会像 switch 语句一样,从第一行开始找
  • 错误做法:把 path: ‘/’ 放在 path: ‘/login’ 前面,且没有加 exact
  • 后果:所有页面都会匹配到 /,导致登录页可能渲染不出来或者被 Layout 包裹

三、权限校验

  • 使用 Umi Wrappers (高阶组件)
  • 配置方式:在路由配置中添加wrappers: ['@/wrappers/auth']
  • 执行逻辑:路由匹配到该层级时,先执行 Wrapper。如果 Wrapper 判断未登录,直接跳转,主 Layout 连加载的机会都没有,彻底杜绝空白或闪屏。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 8:48:44

NBTExplorer:Minecraft数据编辑的图形化解决方案

NBTExplorer&#xff1a;Minecraft数据编辑的图形化解决方案 【免费下载链接】NBTExplorer A graphical NBT editor for all Minecraft NBT data sources 项目地址: https://gitcode.com/gh_mirrors/nb/NBTExplorer 在Minecraft的广阔世界中&#xff0c;数据管理往往成为…

作者头像 李华
网站建设 2026/4/15 19:08:20

ComfyUI-Manager性能调优实战:让老旧设备重获AI创作新生

ComfyUI-Manager性能调优实战&#xff1a;让老旧设备重获AI创作新生 【免费下载链接】ComfyUI-Manager 项目地址: https://gitcode.com/gh_mirrors/co/ComfyUI-Manager 你的ComfyUI是否在低配置设备上运行缓慢、频繁崩溃&#xff1f;内存不足、响应延迟、启动时间过长等…

作者头像 李华
网站建设 2026/4/16 9:04:05

极速汉化Figma:设计师的本地化效率革命

极速汉化Figma&#xff1a;设计师的本地化效率革命 【免费下载链接】figmaCN 中文 Figma 插件&#xff0c;设计师人工翻译校验 项目地址: https://gitcode.com/gh_mirrors/fi/figmaCN 还在为Figma英文界面而苦恼吗&#xff1f;想要零基础快速上手这款顶级设计工具&#…

作者头像 李华
网站建设 2026/4/16 10:14:09

java list怎么进行group

在Java中&#xff0c;对List进行分组有多种方法&#xff0c;以下是常见的几种方式&#xff1a; 1. 使用 Stream API (Java 8 推荐) 1.1 按属性分组 // 按对象属性分组 List<Person> people Arrays.asList(new Person("Alice", "IT"),new Person(…

作者头像 李华
网站建设 2026/4/16 10:16:00

解放校园热水!蓝牙水控器开源项目深度解析

还在为宿舍热水系统烦恼吗&#xff1f;这款开源蓝牙控制方案让你彻底告别复杂的商业应用&#xff0c;实现校园热水系统的自主管理。无论你是技术小白还是开发高手&#xff0c;都能在5分钟内快速上手这款完全离线的校园热水解决方案。 【免费下载链接】waterctl 深圳市常工电子“…

作者头像 李华
网站建设 2026/4/16 10:16:36

鸣潮工具箱终极指南:快速解锁游戏性能潜能的完整方案

鸣潮工具箱终极指南&#xff1a;快速解锁游戏性能潜能的完整方案 【免费下载链接】WaveTools &#x1f9f0;鸣潮工具箱 项目地址: https://gitcode.com/gh_mirrors/wa/WaveTools 还在为《鸣潮》游戏卡顿、画质不佳而烦恼吗&#xff1f;&#x1f9f0;鸣潮工具箱为你提供一…

作者头像 李华