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 API 开发者
Vue是如何进行组件化的
Vue是如何进行组件化的
|
7天前
|
JavaScript 关系型数据库 MySQL
基于VUE的校园二手交易平台系统设计与实现毕业设计论文模板
基于Vue的校园二手交易平台是一款专为校园用户设计的在线交易系统,提供简洁高效、安全可靠的二手商品买卖环境。平台利用Vue框架的响应式数据绑定和组件化特性,实现用户友好的界面,方便商品浏览、发布与管理。该系统采用Node.js、MySQL及B/S架构,确保稳定性和多功能模块设计,涵盖管理员和用户功能模块,促进物品循环使用,降低开销,提升环保意识,助力绿色校园文化建设。
|
1月前
|
JavaScript 前端开发 开发者
Vue是如何劫持响应式对象的
Vue是如何劫持响应式对象的
29 1
|
1月前
|
JavaScript 前端开发 API
介绍一下Vue中的响应式原理
介绍一下Vue中的响应式原理
32 1
|
1月前
|
JavaScript 前端开发 开发者
vue 数据驱动视图
总之,Vue 数据驱动视图是一种先进的理念和技术,它为前端开发带来了巨大的便利和优势。通过理解和应用这一特性,开发者能够构建出更加动态、高效、用户体验良好的前端应用。在不断发展的前端领域中,数据驱动视图将继续发挥重要作用,推动着应用界面的不断创新和进化。
|
1月前
|
JavaScript 前端开发 开发者
Vue是如何进行组件化的
Vue是如何进行组件化的
|
1月前
|
存储 JavaScript 前端开发
介绍一下Vue的核心功能
介绍一下Vue的核心功能
|
1月前
|
JavaScript 前端开发 开发者
vue学习第一章
欢迎来到我的博客!我是瑞雨溪,一名热爱前端的大一学生,专注于JavaScript与Vue,正向全栈进发。博客分享Vue学习心得、命令式与声明式编程对比、列表展示及计数器案例等。关注我,持续更新中!🎉🎉🎉
41 1
vue学习第一章
|
1月前
|
JavaScript 前端开发 索引
vue学习第三章
欢迎来到瑞雨溪的博客,一名热爱JavaScript与Vue的大一学生。本文介绍了Vue中的v-bind指令,包括基本使用、动态绑定class及style等,希望能为你的前端学习之路提供帮助。持续关注,更多精彩内容即将呈现!🎉🎉🎉
30 1
|
1月前
|
缓存 JavaScript 前端开发
vue学习第四章
欢迎来到我的博客!我是瑞雨溪,一名热爱JavaScript与Vue的大一学生。本文介绍了Vue中计算属性的基本与复杂使用、setter/getter、与methods的对比及与侦听器的总结。如果你觉得有用,请关注我,将持续更新更多优质内容!🎉🎉🎉
38 1
vue学习第四章

热门文章

最新文章