vue注册自定义指令,添加权限判断

在utils文件夹创建 directive.js文件

import Vue from 'vue';
import Store from '../store/index.js'

//v-has为编辑权限
Vue.directive("has", {
  inserted: function (el, code) {
    const str = code.value
    const menuName = Store.state.rolePermission
    let list = []
    menuName.forEach(val=>{
      if (val.permissionName == '编辑') {
        list.push(val.menuName)
          // if(val.menuName == str){
          //   el.parentNode.removeChild(el)
          // }
        }
      })
      if(!list.includes(str)){
        el.remove() 
      }
    }
})

//v-dle为删除权限
Vue.directive("dle", {
  inserted: function (el, code) {
    const str = code.value
    const menuName = Store.state.rolePermission
    let list = []
    menuName.forEach(val=>{
      if (val.permissionName == '删除') {
        list.push(val.menuName)
      }
    })
    
    if(!list.includes(str)){
      el.remove() 
    }


  }
})

Store.state.rolePermission的格式如下:

在这里插入图片描述

在页面中使用如下
在这里插入图片描述

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值