Vue 项目路由 + Layout 的最佳实践

文章目录

    • [一、Layout 的真正职责](#一、Layout 的真正职责)
    • [二、推荐的 Layout 结构](#二、推荐的 Layout 结构)
    • [三、路由如何选择 Layout?](#三、路由如何选择 Layout?)
    • [四、Layout 中只做三件事](#四、Layout 中只做三件事)
    • [五、为什么 Layout 一定要放在路由层?](#五、为什么 Layout 一定要放在路由层?)
    • [六、多 Layout 场景实战](#六、多 Layout 场景实战)
    • [七、Layout + 权限的组合优势](#七、Layout + 权限的组合优势)
    • 八、小结

如果你发现:

  • 页面里充满 Header / Sidebar
  • 登录页和业务页结构混在一起
  • 一个页面换布局要改一堆代码

那说明:Layout 没设计好

一、Layout 的真正职责

一句话总结:

Layout 负责页面结构,不负责业务。

二、推荐的 Layout 结构

txt 复制代码
layouts/
├── MainLayout.vue
├── BlankLayout.vue
├── AdminLayout.vue

三、路由如何选择 Layout?

ts 复制代码
{
  path: '/',
  component: MainLayout,
  children: [...]
}

登录页:

ts 复制代码
{
  path: '/login',
  component: BlankLayout,
  children: [...]
}

四、Layout 中只做三件事

  1. 页面结构
  2. 插槽
  3. 通用 UI(Header / Footer)
vue 复制代码
<template>
  <Header />
  <router-view />
</template>

五、为什么 Layout 一定要放在路由层?

因为这样可以:

  • 动态切换布局
  • 权限与布局解耦
  • 路由层表达页面结构

六、多 Layout 场景实战

ts 复制代码
{
  path: '/admin',
  component: AdminLayout,
  children: adminRoutes
}

不同角色看到不同布局,不用改页面代码

七、Layout + 权限的组合优势

  • Layout 控制"长什么样"
  • Router 控制"能不能进"
  • 页面只关心业务

八、小结

Layout 是 UI 骨架,Router 是应用骨架。

这两个分清楚,项目可维护性直接上一个台阶。

相关推荐
乘风gg8 分钟前
为什么AI 时代来临,大部分人吃不到红利
前端·ai编程·claude
恋猫de小郭30 分钟前
Android 限制侧载新进展,谷歌联合国内厂商推验证计划
android·前端·flutter
IT_陈寒36 分钟前
Redis内存爆了,原来我漏掉了这个致命配置
前端·人工智能·后端
恋猫de小郭37 分钟前
解读 Android 17 全新内存限制,有没有“豁免”后门?
android·前端·flutter
Hyyy2 小时前
理解LLM的基本工作原理:预训练、微调、推理的区别
前端
Gatlin2 小时前
前端逆向与反逆向:一场猫鼠游戏的底层逻辑与实战
前端
代码煮茶2 小时前
React 组件封装方法论 —— 以 Todo App 为例
javascript·react.js
Pedantic2 小时前
本地通知(Local Notifications)学习笔记
前端
任沫3 小时前
Agent之Function Call
javascript·人工智能·go
森蓝情丶3 小时前
我给 AI 搭了个法庭:一个前端仔的 LangGraph 实战全记录
前端·后端