按钮级权限是否显示,和权限验证的函数

很多系统后台都有权限的区分,会详细到每一个按钮上,那用的次数很多,这个时候最简单的就是自定义指定去操作. 或者封装处理函数,当用到的时候调用就行了,来判断有没有权限,

先说封装指令:

思路就是把后台传过来的权限数据放到vuex里  然后用指定拿到的数据去判断vuex里面有没有,如果没有权限,就把dom移除了

首先创建permission.js

import store from '../../vuex/store'

function checkPermission(el, binding) {
    const { value } = binding
    const roles = store.state && store.state.userInfo.authorities
    if (value && value instanceof Array) {
        if (value.length > 0) {
            const permissionRoles = value

            const hasPermission = roles.some(role => {
                return permissionRoles.includes(role)
            })

            if (!hasPermission) {
                el.parentNode && el.parentNode.removeChild(el)
            }
        }
    } else {

    }
}

export default {
    inserted(el, binding) {
        checkPermission(el, binding)
    },

}

然后创建authorities.js

import permission from './permission/permission'

const install = function(Vue) {
    Vue.directive('permission', permission)
}

if (window.Vue) {
    window['permission'] = permission
    Vue.use(install); // eslint-disable-line
}

permission.install = install
export default permission

用的时候就是直接引入

import permission from '@/utils/authorities.js';
v-permission="['personal/staff结单']"

下面是处理函数的方法:

export default function checkPermission(value) {
    if (value && value instanceof Array && value.length > 0) {
        const roles = store.state && store.state.userInfo.authorities
        const permissionRoles = value

        const hasPermission = roles.some(role => {
            return permissionRoles.includes(role)
        })
        return hasPermission
    } else {
        console.error(`need roles! Like v-permission="['admin','editor']"`)
        return false
    }
}

直接引入就行了  返回的是布尔值,直接判断是不是有权限,可以做个点击事件,没权限的话做个提示之类的

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值