Vue3+Vite实现根据用户权限的动态路由

 更新时间:2025年10月23日 09:58:16   作者:凉柚ˇ  
在现代前端开发中,单页面应用(SPA)越来越受到开发者的青睐,而 Vue.js 作为其中的一个流行框架,提供了丰富的功能来构建用户界面,本文将通过一个基于 Vite + Vue 3 的项目示例,详细介绍如何实现动态路由,有需要的可以参考下

在现代前端开发中,单页面应用(SPA)越来越受到开发者的青睐,而 Vue.js 作为其中的一个流行框架,提供了丰富的功能来构建用户界面。特别是 Vue 3 的发布,带来了更多的性能优化和新特性。在构建企业级应用时,动态路由是一个不可或缺的功能,它允许应用根据用户权限动态地加载和显示页面。本文将通过一个基于 Vite + Vue 3 的项目示例,详细介绍如何实现动态路由。

首先,确保你已经安装了Node.js和npm(或 yarn)。然后使用Vite创建一个新的Vue 3项目:

npm create vite@latest my-vue-app -- --template vue
cd my-vue-app

然后我们需要进行动态路由的基础配置。

在Vue 3中,我们可以使用createRoutercreateWebHistory(或createMemoryHistory)来创建路由配置。以下是一个基本的路由配置示例:

import { createRouter, createWebHistory } from 'vue-router';

const router = createRouter({
  history: createWebHistory(),
  routes: [
    // ...路由配置
  ]
});

接下来,我们需要进行权限控制,这是动态路由实现的关键。通常,后端会提供一个权限列表,前端根据这些信息动态地添加或删除路由。

在提供的代码中,我们可以看到几个关键点:

  • 路由配置数组(routes):定义了应用的基础路由结构。
  • 路由守卫(router.beforeEach):在路由跳转前进行权限检查。
  • 动态路由添加(setPermissions函数):根据用户权限动态添加路由。

路由守卫是Vue Router的一个强大功能,可以在路由跳转前后执行代码。在本例中,我们使用了beforeEach守卫来检查用户是否登录,以及是否具有相应的权限。

router.beforeEach((to) => {
  if (to.name !== 'login') {
    if (!store.state.auth) {
      router.push({ name: 'login' });
      return false;
    }
    if (!store.state.permissions) {
      setPermissions(to.path);
      return false;
    }
    NProgress.start();
  }
});

setPermissions函数是动态路由实现的核心。它首先从后端获取所有权限列表,然后与用户实际拥有的权限进行匹配,最后动态地添加路由。

function setPermissions(routerPath) {
  getPermList({}).then((allPermissions) => {
    // ...权限过滤和路由添加逻辑
  });
}

在动态路由中,异步组件的使用可以提高应用的性能。Vue支持使用import()函数来定义异步组件,这允许我们在需要时才加载组件。

router.addRoute('Admin', {
  path: permission.perm_router_path,
  name: permission.perm_router_name,
  component: () => import(`../views/${permission.perm_component_path}.vue`)
});

在实际开发中,还有一些注意事项需要注意:

  • 确保后端接口正确返回权限数据。
  • 动态路由的添加应该在应用启动后尽快完成,避免用户在没有权限的页面上等待。
  • 考虑使用Vuex或其他状态管理库来管理用户状态和权限。

通过本文的介绍,你应该对如何在Vue 3 + Vite项目中实现动态路由有了更深入的理解。动态路由是一个复杂但非常有用的功能,合理使用可以大大提升应用的安全性和用户体验。希望本文对你有所帮助!

完整代码示例

// 引入了状态管理与NProgress进度条
import store from '../store'
import { createRouter, createWebHistory } from 'vue-router'
import NProgress from 'nprogress'
import { getPermList } from '../axios/apiPermission'

import Admin from '../layout/Admin.vue'
import Index from '../views/Index.vue'
import Setting from '../views/Setting.vue'
import Login from '../views/Login.vue'

const routes = [
  {
    path: '/',
    name: 'Admin',
    component: Admin,
    redirect: '/index',
    children: [
      {
        path: '/index',
        name: 'Index',
        component: Index
      },
      {
        path: '/setting',
        name: 'Setting',
        component: Setting
      },
     // ...
    ]
  },
  {
    path: '/:pathMatch(.*)',
    component: Index
  },
  {
    path: '/login',
    name: 'login',
    component: Login
  }
]

const router = createRouter({
  history: createWebHistory(),
  routes
})

function setPermissions(routerPath) {
  getPermList({})
    .then((allPermissions) => {
      // 从store中获取用户实际拥有的权限
      const userPermissions = store.state.auth.permissions

      // 过滤出用户实际拥有的权限
      const filteredPermissions = allPermissions.filter((permission) => {
        return userPermissions.some((userPerm) => userPerm.perm_id === permission.perm_id)
      })
      store.dispatch('setPermissions', filteredPermissions).then(() => {
        filteredPermissions.forEach((category) => {
          if (category.children && category.children.length > 0) {
            category.children.forEach((permission) => {
              // 根据用户权限动态添加路由
              if (permission.perm_component_path.includes('/')) {
                const parts = permission.perm_component_path.split('/')
                const firstPart = parts[0]
                const secondPart = parts[1]
                router.addRoute('Admin', {
                  path: permission.perm_router_path,
                  name: permission.perm_router_name,
                  component: () => import(`../views/${firstPart}/${secondPart}.vue`)
                })
              } else {
                router.addRoute('Admin', {
                  path: permission.perm_router_path,
                  name: permission.perm_router_name,
                  component: () => import(`../views/${permission.perm_component_path}.vue`)
                })
              }
            })
          }
        })

        router.push({ path: routerPath || '/' })
      })
    })
    .catch((error) => {
      console.error('获取权限错误:', error)
    })
}

NProgress.inc()
NProgress.configure({ showSpinner: false })

router.beforeEach((to) => {
  if (to.name !== 'login') {
    if (!store.state.auth) {
      router.push({ name: 'login' })
      return false
    }
    if (!store.state.permissions) {
      setPermissions(to.path)
      return false
    }
    NProgress.start()
  }
})
router.afterEach(() => {
  NProgress.done()
})

export default router

到此这篇关于Vue3+Vite实现根据用户权限的动态路由的文章就介绍到这了,更多相关Vue3动态路由内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • vuejs2.0运用原生js实现简单的拖拽元素功能示例

    vuejs2.0运用原生js实现简单的拖拽元素功能示例

    本篇文章主要介绍了vuejs2.0运用原生js实现简单的拖拽元素功能示例,具有一定的参考价值,感兴趣的小伙伴们可以参考一下。
    2017-02-02
  • vue搜索和vue模糊搜索代码实例

    vue搜索和vue模糊搜索代码实例

    这篇文章主要介绍了vue搜索和vue模糊搜索,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-05-05
  • vue 动态添加/删除dom元素节点的操作代码

    vue 动态添加/删除dom元素节点的操作代码

    这篇文章主要介绍了vue 动态添加/删除dom元素,需要在点击添加时,增加一行key/value的输入框;点击垃圾桶图标时,删除对应行,本文结合实例代码给大家讲解的非常详细,需要的朋友可以参考下
    2022-12-12
  • 如何使用vue实现跨域访问第三方http请求

    如何使用vue实现跨域访问第三方http请求

    这篇文章主要介绍了如何使用vue实现跨域访问第三方http请求,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2024-03-03
  • vue.js中proxyTable 转发请求的实现方法

    vue.js中proxyTable 转发请求的实现方法

    今天小编就为大家分享一篇vue.js中proxyTable 转发请求的实现方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-09-09
  • Vue3中pinia的使用与持久化处理详解

    Vue3中pinia的使用与持久化处理详解

    Pinia 是一个基于 Vue 3 的状态管理库,可以更好地支持 TypeScript 和更灵活的状态管理方式,本文主要介绍了pinia的使用与持久化处理,需要的可以参考一下
    2023-07-07
  • vue使用Element组件时v-for循环里的表单项验证方法

    vue使用Element组件时v-for循环里的表单项验证方法

    这篇文章主要介绍了vue使用Element组件时v-for循环里的表单项验证方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-06-06
  • VUE学习宝典之el-dialog使用示例

    VUE学习宝典之el-dialog使用示例

    在我工作过程中使用el-dialog的需求挺多的,也积累了一下使用技巧,这篇文章主要给大家介绍了关于VUE学习宝典之el-dialog使用的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2024-03-03
  • vue cli使用融云实现聊天功能的实例代码

    vue cli使用融云实现聊天功能的实例代码

    最近小编接了一个新项目,项目需求要实现一个聊天功能,今天小编通过实例代码给大家介绍vue cli使用融云实现聊天功能的方法,感兴趣的朋友跟随小编一起看看吧
    2019-04-04
  • 利用nginx部署vue项目的全过程

    利用nginx部署vue项目的全过程

    今天要用到服务器nginx,还需要把自己的vue的项目部署到服务器上去所以就写一下记录下来,下面这篇文章主要给大家介绍了关于利用nginx部署vue项目的相关资料,需要的朋友可以参考下
    2022-03-03

最新评论