Vue实现按钮级别权限

简介: 文章介绍了在Vue中实现按钮级别权限的两种方法:使用自定义Vue指令和使用v-if指令配合自定义方法。

Vue实现按钮级别权限

我这里分为了两种,先上图:
在这里插入图片描述
修改、删除使用的是vue指令实现,操作 这一列使用的是v-if。
ui组件使用的是element_table组件。

准备工作:

首先,我们需要有一个所有的btn权限的list,重置好变量即可:
const BtnList = {
   
    getRoleList: "/sys/role/getRoleList",
    getMenuAreaBtnTree: "/sys/role/getMenuAreaBtnTree",
    addRole: "/sys/role/addRole",//新增角色
    getUserRole: "/sys/user/getUserRole",
    updateRole: "/sys/role/updateRole",//修改角色
    deleteRole: "/sys/role/deleteRole",//删除角色
    updateUserRole: "/sys/user/updateUserRole",//更新用户角色
}
export default BtnList

//使用:
import BtnList from '@/utils/btnPermissions/BtnPermission'
//挂载到Vue实例上
// 所有的btn权限list
Vue.prototype.$BtnList = BtnList

一、第一种使用的是vue指令。

定义自定义指令:
/*
 * @Descripttion: 
 * @version: 
 * @Author: ZhangJunQing
 * @Date: 2022-07-11 17:24:19
 * @LastEditors: ZhangJunQing
 * @LastEditTime: 2022-07-22 09:55:35
 */

import store from '@/store'
const permission = {
   
    inserted(el, binding, vnode) {
   
        // console.log(binding,'binding')
        /*el: 指令所绑定的元素,可以用来直接操作DOM。
           binding: 一个对象,包含指令的很多信息。
           vnode: Vue编译生成的虚拟节点。*/
        const {
    value } = binding
        // 在登录后就可以缓存当前用户的btn权限。
        // sessionStorage.setItem('ButtonPermissions',JSON.stringify(['role:add']))
        // 自定义指令的执行函数,,取到登录缓存的按钮权限数组,赋值给全局对象userMsg
        global.ButtonPermissions = store.state.home.checkBtn
        // global.ButtonPermissions = JSON.parse(sessionStorage.getItem('ButtonPermissions'))
        if (global.ButtonPermissions && global.ButtonPermissions.indexOf(value) < 0) {
   
            el.style.display = 'none'
        }
    }
}
// 全局注册自定义指令
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

// v-permission="aaaaa"

Vue.directive自定义指令:该指令可以写一个自定义的事件*
自定义指令中传递的三个参数
el: 指令所绑定的元素,可以用来直接操作DOM。
binding: 一个对象,包含指令的很多信息。
vnode: Vue编译生成的虚拟节点。
自定义指令的生命周期
自定义指令有五个生命周期(也叫钩子函数),分别是 bind,inserted,update,componentUpdated,unbind
bind:只调用一次,指令第一次绑定到元素时调用,用这个钩子函数可以定义一个绑定时执行一次的初始化动作。
1 inserted:被绑定元素插入父节点时调用(父节点存在即可调用,不必存在于document中)。
2 update:被绑定于元素所在的模板更新时调用,而无论绑定值是否变化。通过比较更新前后的绑定值,可以忽略不必要的模板更新。
3 componentUpdated:被绑定元素所在模板完成一次更新周期时调用。
4 unbind:只调用一次,指令与元素解绑时调用。

使用:
import BtnPermissionDirectives from '@/utils/btnPermissions/BtnPermissionDirectives'

// 注册按钮权限 自定义指令
Vue.use(BtnPermissionDirectives)
在页面中使用:
    <el-table-column
          label="操作"
          align="center"
        >
          <template slot-scope="scope">
            <el-button
              type="text"
              icon="el-icon-edit"
              @click="UpdateRoleManageFun(scope.row)"
              v-permission="$BtnList.updateRole"
              >修改</el-button
            >
            <el-button
              type="text"
              icon="el-icon-delete"
              class="red"
              @click="handleDelete(scope.row)"
              v-permission="$BtnList.deleteRole"
              >删除</el-button
            >
          </template>
        </el-table-column>

上述过程即可实现自定义指令控制按钮的显示隐藏。

一、第二种使用的是v-if配合自定义方法。

CBF 方法
// checkUserIsHasFun
// 使用

// v-if="$CBF($BtnList.updateUserRole + '+=+' + '111')"

export const CBF = (value) => {
   
    let checkBtnList = store.state.home.checkBtn
    // +=+
    // 如果需要两个权限变量配合显示与否
    // 传入的时候请使用 +=+ 拼接
    // 例如: v-permission="$BtnList.updateUserRole+''+$BtnList.updateUserRole"
    if (value.indexOf('+=+') !== -1) {
   
        // 存在双层关系
        // 两个都不在btn权限list里面的时候才会 display === none
        // 有一个的时候就显示  也就是啥也不做......
        let valueArr = value.split('+=+')
        // for
        // let booleanFlag = valueArr.every(item =>
        //     checkBtnList && checkBtnList.indexOf(item) < 0
        // )
        // if (!booleanFlag) {
   
        //     return true
        // }
        // return false
        return !valueArr.every(item =>
            checkBtnList && checkBtnList.indexOf(item) < 0
        )
    } else {
   
        if (checkBtnList && checkBtnList.indexOf(value) < 0) {
   
            return false
        }
        return true
    }
}
挂载到vue实例上
import BtnList, {
    CBF } from '@/utils/btnPermissions/BtnPermission'

// 主要用于表格列属性
// 例如 下面有一个修改、一个删除 两个按钮
// 只有两个按钮的权限都为false的时候
// 才会将这一列隐藏
Vue.prototype.$CBF = CBF
页面使用:
      <el-table-column
         label="操作"
         v-if="$CBF($BtnList.updateRole + '+=+' + $BtnList.deleteRole)"
         align="center"
       >
         <template slot-scope="scope">
           <el-button
             type="text"
             icon="el-icon-edit"
             @click="UpdateRoleManageFun(scope.row)"
             v-permission="$BtnList.updateRole"
             >修改</el-button
           >
           <el-button
             type="text"
             icon="el-icon-delete"
             class="red"
             @click="handleDelete(scope.row)"
             v-permission="$BtnList.deleteRole"
             >删除</el-button
           >
         </template>
     </el-table-column>
主要是:
 v-if="$CBF($BtnList.updateRole + '+=+' + $BtnList.deleteRole)"

即可,我们使用+=+来拼接多个按钮权限。

目录
相关文章
|
1天前
|
JavaScript
Vue使用element中table组件实现单选一行
如何在Vue中使用Element UI的table组件实现单选一行的功能。
12 5
Vue使用element中table组件实现单选一行
|
1天前
|
JavaScript
Vue+element_Table树形数据与懒加载报错Error in render: “RangeError: Maximum call stack size exceeded“
本文讨论了在使用Vue和Element UI实现树形数据和懒加载时遇到的“Maximum call stack size exceeded”错误,指出问题的原因通常是因为数据中的唯一标识符`id`不唯一,导致递归渲染造成调用栈溢出。
7 1
Vue+element_Table树形数据与懒加载报错Error in render: “RangeError: Maximum call stack size exceeded“
|
2天前
|
JavaScript
vue知识点
vue知识点
12 4
|
2天前
|
存储 JavaScript
vue页面跳转取消上一个页面请求
本文介绍了在Vue中如何取消上一个页面的请求,以避免页面跳转时请求未完成导致的数据错误。核心方法是使用axios的请求拦截器设置请求的取消令牌(cancelToken),并在vuex中存储这些取消令牌的引用。当进行路由跳转时,通过路由守卫清除这些请求,达到取消上一个页面请求的目的。
13 2
|
1天前
|
JavaScript
vue第一个项目之音乐播放器
vue第一个项目之音乐播放器
|
8天前
|
JavaScript
vue 函数化组件
vue 函数化组件
|
5天前
|
JavaScript
vue异步渲染
vue异步渲染
|
9天前
|
JavaScript
vue中watch的用法
vue中watch的用法
|
3天前
|
JavaScript API
vue使用hook:声明周期来监听子组件的声明周期
本文介绍了如何在Vue中使用生命周期钩子来监听子组件的生命周期事件,包括在子组件内部监听和在父组件中监听子组件的生命周期钩子。
17 0
|
9天前
|
JavaScript 前端开发
vue动态添加style样式
vue动态添加style样式