Vue Router 权限系统设计实战

@[toc]

在 Vue 项目里,权限问题永远不是"有没有",而是"会不会失控"

一开始可能只是:

  • 登录校验
  • 菜单控制
  • 页面访问限制

但随着业务复杂度上来,很容易演变成:

  • 路由守卫越写越多
  • 页面里到处是 if (hasPermission)
  • 前后端权限逻辑不一致

这篇文章,我们不讲"能跑的权限",而是讲可扩展、可维护、长期稳定的权限系统设计

一、先明确:权限系统到底在管什么?

先给一个非常重要的拆分:

权限 = 三件事

  1. 能不能进这个路由
  2. 能不能看到这个页面的入口
  3. 能不能执行某个操作(按钮级)

这篇文章重点讲 第 1 件事:路由权限

二、权限设计的核心原则

在任何中大型项目里,下面三条原则一定要守住。

原则一:权限是"声明式"的

路由只声明自己需要什么权限,而不是怎么判断。

ts 复制代码
meta: {
  requiresAuth: true,
  roles: ['admin']
}

原则二:权限判断逻辑集中

绝不分散在页面、组件、API 调用里。

原则三:路由权限 ≠ 菜单权限

  • 路由权限:是否允许访问 URL
  • 菜单权限:是否展示入口

两者相关,但不要强耦合。

三、基础路由权限模型

路由声明

ts 复制代码
{
  path: '/admin',
  component: () => import('@/views/admin/index.vue'),
  meta: {
    requiresAuth: true,
    roles: ['admin']
  }
}

全局守卫

ts 复制代码
router.beforeEach((to, from, next) => {
  if (to.meta.requiresAuth && !isLogin()) {
    return next('/login')
  }
  next()
})

这是最基础的一层,但还远远不够。

四、角色权限系统的正确写法

权限判断函数集中化

ts 复制代码
function hasPermission(routeRoles: string[]) {
  const userRoles = getUserRoles()
  return routeRoles.some(role => userRoles.includes(role))
}

权限守卫

ts 复制代码
router.beforeEach((to, from, next) => {
  const { roles } = to.meta
  if (roles && !hasPermission(roles)) {
    return next('/403')
  }
  next()
})

好处:

  • 权限逻辑只有一个入口
  • 改规则不用全局搜代码

五、动态路由与后端权限

中后台项目几乎都会遇到:

路由由后端返回,前端动态注册

后端返回示例

json 复制代码
[
  {
    "path": "/order",
    "component": "order/index",
    "roles": ["admin"]
  }
]

前端动态注册

ts 复制代码
const asyncRoutes = mapBackendRoutes(routesFromServer)
asyncRoutes.forEach(route => {
  router.addRoute(route)
})

关键点

  • 前端仍然保留权限校验
  • 后端负责"能看到什么"
  • 前端负责"能不能访问"

六、权限与页面逻辑解耦

错误示例:

vue 复制代码
<button v-if="user.role === 'admin'">删除</button>

正确做法:

ts 复制代码
const canDelete = usePermission('delete_order')

统一用权限 Hook / 方法,避免散落逻辑。

七、实战总结

一个稳定的 Vue Router 权限系统应该做到:

  • 路由声明权限
  • 守卫集中判断
  • 页面不感知权限逻辑
  • 支持后端动态配置
相关推荐
吴声子夜歌9 分钟前
ES6——二进制数组详解
前端·ecmascript·es6
码事漫谈37 分钟前
手把手带你部署本地模型,让你Token自由(小白专属)
前端·后端
ZC跨境爬虫41 分钟前
【爬虫实战对比】Requests vs Scrapy 笔趣阁小说爬虫,从单线程到高效并发的全方位升级
前端·爬虫·scrapy·html
爱上好庆祝42 分钟前
svg图片
前端·css·学习·html·css3
橘子编程1 小时前
JavaScript与TypeScript终极指南
javascript·ubuntu·typescript
王夏奇1 小时前
python中的__all__ 具体用法
java·前端·python
叫我一声阿雷吧2 小时前
JS 入门通关手册(45):浏览器渲染原理与重绘重排(性能优化核心,面试必考
javascript·前端面试·前端性能优化·浏览器渲染·浏览器渲染原理,重排重绘·reflow·repaint
大家的林语冰2 小时前
《前端周刊》尤大开源 Vite+ 全家桶,前端工业革命启动;尤大爆料 Void 云服务新产品,Vite 进军全栈开发;ECMA 源码映射规范......
前端·javascript·vue.js
jiayong232 小时前
第 8 课:开始引入组合式函数
前端·javascript·学习
田八2 小时前
聊聊AI的发展史,AI的爆发并不是偶然
前端·人工智能·程序员