前端自定义指令控制权限(后端Spring Security)

1. 新建 directives/auth.ts

javascript 复制代码
//导入自定义指令
import auth from '@/directives/auth'// 注册全局自定义指令 v-auth
app.directive('auth', auth);

1.1完整的authDirective.ts

javascript 复制代码
import { wmsStore } from "@/store/pinia"

// 判断用户是否有某个角色的函数
const hasRoles = (roles: any) => {

  const pinaRoles: any = wmsStore().roles;

  if (Array.isArray(roles)) {
    return roles.some(role => pinaRoles.includes(role));
  } else if (typeof roles === 'string') {
    return pinaRoles.includes(roles);
  } else {
     return false
  }

}
// 判断用户是否有某个权限的函数,同上
const hasPermissions = (permission: any) => {

  return true
}

// 创建自定义指令
export default {
  mounted(el: HTMLElement, binding: any) {
 
    const type = binding.arg
    if (type === 'role') {
      if (!hasRoles(binding.value)) {
        el.remove()
      }
    }
  },
};
  

2.如何使用

2.1 菜单使用方式

2.2 按钮使用

相关推荐
@菜菜_达1 分钟前
goldenLayout布局
前端·javascript
Shirley~~2 分钟前
vite的tersor在lib库模式下不生效问题
javascript·vue.js·ecmascript
小飞侠在吗2 分钟前
vue 生命周期
前端·javascript·vue.js
魂祈梦2 分钟前
ElementUI组件出现大量重复样式
vue.js·element·scss
cindershade5 分钟前
Vue3 + Keep-Alive:实习中遇到的 window 滚动问题与实践
vue.js
小王码农记38 分钟前
CSS中自定义属性函数var()
前端·css·vue.js
泉城老铁1 小时前
springboot+vue 如何实现海康摄像头喊话功能
前端·vue.js·后端
一 乐1 小时前
美食推荐|基于springboot+vue的美食分享系统设计与实现(源码+数据库+文档)
前端·数据库·vue.js·spring boot·后端·美食
WX-bisheyuange1 小时前
基于Spring Boot的电影院购票系统设计与实现
前端·javascript·vue.js·毕业设计
聊天QQ:688238861 小时前
基于Matlab与Simulink的滑模控制六自由度水下机器人运动模型:无缝轨迹跟踪,含S-f...
vue.js