Install
npx skillscat add tencentblueking/bk-bcs/iam Install via the SkillsCat registry.
SKILL.md
前端权限控制方案 (IAM)
在蓝鲸体系中,权限控制不仅仅是“显示/隐藏”,更重要的是**“发现与申请”。我们推荐使用“置灰 + 提示申请”**的交互模式。
1. 核心指令 v-authority
这个指令会自动处理点击拦截、样式置灰和申请弹窗的唤起。
使用方式:
<bk-button v-authority="{ permission: hasAuth, actionId: 'host_edit' }">
编辑
</bk-button>指令功能:
- 有权限 → 正常交互
- 无权限 → 置灰 + 点击触发申请弹窗 + Tooltip 提示
📦 获取完整指令实现:
skill://permission-directive/assets/authority-directive.ts
2. 鉴权组件 AuthButton
对于需要更多自定义的场景,可封装鉴权按钮组件。
3. 路由级鉴权
在 vue-router 的 beforeEach 中处理页面级权限。
router.beforeEach(async (to, from, next) => {
const meta = to.meta as any;
if (meta.auth) {
const hasAuth = await checkPageAuth(meta.authAction);
if (!hasAuth) {
next({ name: '403', query: { action: meta.authAction } });
return;
}
}
next();
});📦 可用资源
skill://permission-directive/assets/authority-directive.ts
根据 SKILL.md 中的 IF-THEN 规则判断是否需要加载