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 是应用骨架。

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

相关推荐
Kagol1 小时前
🎉OpenTiny NEXT-SDK 重磅发布:四步把你的前端应用变成智能应用!
前端·开源·agent
GIS之路2 小时前
ArcGIS Pro 中的 notebook 初识
前端
JavaGuide2 小时前
7 道 RAG 基础概念知识点/面试题总结
前端·后端
ssshooter2 小时前
看完就懂 useSyncExternalStore
前端·javascript·react.js
格砸3 小时前
从入门到辞职|从ChatGPT到OpenClaw,跟上智能时代的进化
前端·人工智能·后端
Live000004 小时前
在鸿蒙中使用 Repeat 渲染嵌套列表,修改内层列表的一个元素,页面不会更新
前端·javascript·react native
柳杉4 小时前
使用Ai从零开发智慧水利态势感知大屏(开源)
前端·javascript·数据可视化
兆子龙4 小时前
从高阶函数到 Hooks:React 如何减轻开发者的心智负担(含 Demo + ahooks 推荐)
前端
狗胜4 小时前
测试文章 - API抓取
前端