自定义按钮指令

1,明确后台返回的按钮权限格式,我这边的格式是:

permissionBtn:["infoAdd","infoExport","infoDel"]

2,在登录的时候将数据存放在状态管理里面去:

commit('PERMISSION_BTN', permissionBtn)

        当然,这是在登陆后查询用户的情况下获取的,如果你是在登录的时候获取的,得把数据存在本地。否则的话,页面刷新存放在vuex里面的权限列表会被格式化。存放数据如下:

setStorage('PermissionBtn', JSON.stringify(permissionBtn))

3,创建一个hasPermission.js文件,里面内容如下:

import Vue from 'vue'
import store from '@/store'
// import { getStorage } from '@/utils/storage'

const permissionBtn = Vue.directive('per', {
  inserted: function (el, binding, vnode) {
    if (!Vue.prototype.$PERMISSION(binding.value)) {
      el.remove()
    }
  }
})

Vue.prototype.$PERMISSION = function (value) {
  let isPermission = false
  const buttonPermission = store.state.user.permissionBtn // 存放在vuex的写法
  // const buttonPermission = getStorage('PermissionList') // 存放在本地存储的写法
  if (buttonPermission === undefined || buttonPermission === null) {
    return false
  }
  try {
    const targetArr = value.split(',')
    for (let i = 0; i < targetArr.length; i++) {
      if (buttonPermission.includes(targetArr[i])) {
        isPermission = true
        break
      }
    }
    return isPermission
  } catch {
    console.log('error')
    isPermission = false
    return isPermission
  }
}

export {
  permissionBtn
}

4,在main.js中引入,引入地址依情况而定。

import './hasPermissionbtn'

5,直接在页面中使用,可以在任何标签中使用:

<btn buttonname='按钮' v-per="'infoAdd'" />

如果是多个权限或控制按钮时通过 “,”隔开v-per=" 'infoAdd,infoedit ' ",表示权限里面有"infoAdd"或者"infoedit"都显示该按钮。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值