23 lines
667 B
TypeScript
Raw Normal View History

2022-10-18 15:07:42 +08:00
import { type Directive } from "vue"
import { useUserStoreHook } from "@/store/modules/user"
/** 权限指令 */
export const permission: Directive = {
mounted(el, binding) {
const { value } = binding
const { roles } = useUserStoreHook()
if (Array.isArray(value) && value.length > 0) {
const permissionRoles = value
const hasPermission = roles.some((role) => permissionRoles.includes(role))
if (!hasPermission) {
// 隐藏
// el.style.display = "none"
// 销毁
el.parentNode?.removeChild(el)
}
} else {
throw new Error(`need roles! Like v-permission="['admin','editor']"`)
}
}
}