vue实现不同用户权限的方法

news/2025/3/26 18:22:21/文章来源:https://www.cnblogs.com/zxlh1529/p/18790227

Vue 实现不同用户权限的方法

在项目中,实现不同用户的权限控制是常见的需求也是常见的功能模块,例如管理系统中不同角色(管理员、普通用户等)应有不同的访问权限,小程序、App等在不同角色登入的时候显示的首页以及跳转访问不同的页面。本文将以 vue 为主要的代码框架介绍几种常见的权限控制方式。

1. 基于路由守卫的权限控制

1.1 方案概述

基于 Vue Router 的 beforeEach 进行全局路由守卫控制。我们可以在 vuexpinia 中存储用户角色,并在路由的 meta 字段中定义允许访问的角色。

1.2 实现步骤

  1. router 配置中为每个路由添加 meta 字段,存储允许访问的角色。
  2. 在 Vuex/Pinia 中存储用户角色。
  3. 使用 router.beforeEach 进行权限校验。

1.3 代码示例

// router/index.js
import { createRouter, createWebHistory } from 'vue-router';
import store from '@/store';// 引入多个组件页面 
import Home from '@/views/Home.vue';
import Admin from '@/views/Admin.vue';
import AddSomeFun from '@/views/AddSomeFun.vue';
import Login from '@/views/Login.vue';// 定义路由,并且在 meta 中定义可访问的角色
const routes = [{ path: '/', component: Home },{ path: '/admin', component: Admin, meta: { roles: ['admin'] } },{ path: '/addSomeFun', component: AddSomeFun, meta: { roles: ['user'] } },{ path: '/login', component: Login }
];// 创建路由
const router = createRouter({history: createWebHistory(),routes
});// 路由校验
router.beforeEach((to, from, next) => {const userRole = store.state.userRole; // 假设 Vuex 中存储了用户 user、管理员 admin 角色if (to.meta.roles && !to.meta.roles.includes(userRole)) {next('/'); // 无权限跳转到首页} else {next();}
});export default router;

2. 基于 Vue 指令的权限控制

2.1 方案概述

使用 Vue 指令 v-permission 来控制按钮、组件或模块的显示隐藏。

2.2 实现步骤

  1. 在 Vue 全局创建一个自定义指令 v-permission
  2. 该指令根据用户权限判断是否显示该元素。

2.3 代码示例

// directives/permission.js
// 指令封装
import { useStore } from 'vuex';export default {install(app) {app.directive('permission', {mounted(el, binding) {const store = useStore();const userRole = store.state.userRole;if (!binding.value.includes(userRole)) {el.parentNode?.removeChild(el);}}});}
};
// main.js
import { createApp } from 'vue';
import App from './App.vue';
import store from './store';
import permissionDirective from './directives/permission';const app = createApp(App);
app.use(store);
app.use(permissionDirective); // 注册自定义指令
app.mount('#app');
<!-- 使用示例 -->
<button v-permission="['admin']">仅管理员可见</button>

3. 基于 Vuex(或 Pinia)的权限控制

3.1 方案概述

在 Vuex/Pinia 中存储权限信息,并在组件中通过 computed 计算属性动态控制组件或按钮的显示。

3.2 代码示例

// store/index.js
import { createStore } from 'vuex';export default createStore({state: {userRole: 'user' // 假设存储用户角色},mutations: {setUserRole(state, role) {state.userRole = role;}}
});
<!-- 在组件中使用 Vuex 进行权限判断 -->
<template><button v-if="userRole === 'admin'">仅管理员可见</button>
</template><script>
import { computed } from 'vue';
import { useStore } from 'vuex';export default {setup() {const store = useStore();const userRole = computed(() => store.state.userRole);return { userRole };}
};
</script>

4. 后端返回权限控制

4.1 方案概述

后端返回权限控制的方式有两种:

  1. 返回用户权限信息:前端获取角色信息后,使用前述方法进行权限控制。
  2. 后端返回可访问路由:后端返回用户可以访问的路由列表,前端使用 router.addRoute 动态注册。

4.2 代码示例(后端返回路由)

// 登录后获取用户权限,并动态添加路由
import router from '@/router';
import store from '@/store';
import axios from 'axios';async function fetchUserRoutes() {const res = await axios.post('/common/getUserRoutes'); // 假设后端返回路由信息const routes = res.dataroutes.forEach(route => {router.addRoute(route);});
}fetchUserRoutes();

5. 总结

方法 适用场景 优势 缺点
路由守卫 页面级权限控制 适用于完整页面权限 无法控制按钮等细节
Vue 指令 组件、按钮级权限 适用于 UI 级别权限 需要手动移除元素
Vuex/Pinia 组件级权限 适用于灵活权限判断 需要在多个组件中维护权限逻辑
后端返回权限 适用于大规模权限管理 后端统一管理,灵活 需要动态更新前端路由

以上几种方式可以结合使用,根据实际业务需求选择合适的权限控制方式。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/905005.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

第六天

单词 以下是今天需学习的35个单词复习,同时前几天的单词阅读 理解文章大意,记录不认识的单词。今天这个阅读非常应当下的情景。 How to Teach Yourself Anything in Less than Three Months 如何在3个月内学习任何一件事(一) Self-education can be wonderful and frustrat…

React Native开发鸿蒙Next---富文本浏览

React Native开发鸿蒙Next---富文本浏览 最近在继续开发App剩余的社区功能。地铁的社区相对较为特殊,只有公告/政策规章/操作指南等资讯阅读功能,无法进行交互。对于原先的社区RN,除了移植适配鸿蒙,还需要做大量的功能屏蔽等改造。新的社区后台大量采用富文本进行内容编辑,…

17.指针

正如您所知道的,每一个变量都有一个内存位置,每一个内存位置都定义了可使用 & 运算符访问的地址,它表示了在内存中的一个地址。 请看下面的实例,它将输出定义的变量地址:#include <stdio.h>int main(){int var_runoob = 10;int *p; //定义指针变量p = &var…

3.24 学习记录

实现了学习记录APP的登录注册功能

2025西安交大集训Day2:DFS,BFS记忆化搜索,迭代加深搜索,二分搜索

2025西安交大集训Day2:DFS,BFS记忆化搜索,迭代加深搜索,二分搜索

掌握 Postman:高级 GET 请求技术与响应分析

欢迎阅读本指南,它将详细介绍如何在 Postman 中发送 GET 请求并理解 API 响应。对于希望提升 API 测试和开发能力的开发者来说,这是不可或缺的技能。 Postman 对开发者的重要性Postman 是 API 开发和测试中不可或缺的工具。它不仅简化了发送请求和分析响应的过程,还提供了一…

带你一起来熟悉linux文件权限体系

了解 Linux 文件权限对于有效且可靠的linux相关系统管理和安全管理至关重要。通过本文中概述的概念并加以实践,您将可以轻松浏览文件权限并确保 Linux 系统的完整,可靠和安全。下面将从权限的格式,常用设置,修改,解析等方面分别说明。 A).Linux 文件权限由三个权限部分组成…

OP100自动安装背板常见问题

1.运行过程中切手动,回原灯一直闪烁,始终无法执行完成 OP50自动安装座板 OP100自动安装背板 OP280自动安装上盖 这几个工站因为有记忆功能,会记住当前步序以及夹爪/吸盘上有没有物体,如果运行中切换手动,并动了气缸,会导致逻辑错乱,类似升降器的SUB40,遇到这种情况: 1…

20244217 2024-2025-2 《Python程序设计》实验一报告

学号 2024-2025-2 《Python程序设计》实验一报告 课程:《Python程序设计》 班级: 2442 姓名: 胡峻豪 学号:20244217 实验教师:王志强 实验日期:2025年3月24日 必修/选修: 公选课 1.实验内容 1.熟悉Python开发环境。首先在官网下载并安装PyCharm专业版,安装完成后打开软…

软件工程日报15

Android studio 实现连接远程mysql数据库,并将数据展示出来,由于之前没接触过,全靠按照博客上的指导和ai生成的代码,之后在学习一下 以下是效果

《Python程序设计》实验一报告

课程:《Python程序设计》 班级: 2441 姓名: 王晓凤 学号:20244127 实验教师:王志强 实验日期:2025年3月24日 必修/选修: 公选课 一.实验内容 1.熟悉Python开发环境:本次实验使用了PyCharm。首先在官网下载并安装PyCharm社区版,安装完成后打开软件,创建一个新的Pytho…