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)"

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

目录
相关文章
|
8月前
|
JavaScript
Vue中如何实现兄弟组件之间的通信
在Vue中,兄弟组件可通过父组件中转、事件总线、Vuex/Pinia或provide/inject实现通信。小型项目推荐父组件中转或事件总线,大型项目建议使用Pinia等状态管理工具,确保数据流清晰可控,避免内存泄漏。
729 2
|
7月前
|
缓存 JavaScript
vue中的keep-alive问题(2)
vue中的keep-alive问题(2)
616 137
|
11月前
|
人工智能 JavaScript 算法
Vue 中 key 属性的深入解析:改变 key 导致组件销毁与重建
Vue 中 key 属性的深入解析:改变 key 导致组件销毁与重建
1163 0
|
11月前
|
JavaScript UED
用组件懒加载优化Vue应用性能
用组件懒加载优化Vue应用性能
|
10月前
|
人工智能 JSON JavaScript
VTJ.PRO 首发 MasterGo 设计智能识别引擎,秒级生成 Vue 代码
VTJ.PRO发布「AI MasterGo设计稿识别引擎」,成为全球首个支持解析MasterGo原生JSON文件并自动生成Vue组件的AI工具。通过双引擎架构,实现设计到代码全流程自动化,效率提升300%,助力企业降本增效,引领“设计即生产”新时代。
733 1
|
10月前
|
JavaScript 安全
在 Vue 中,如何在回调函数中正确使用 this?
在 Vue 中,如何在回调函数中正确使用 this?
518 0
|
11月前
|
JavaScript 前端开发 UED
Vue 表情包输入组件实现代码及详细开发流程解析
这是一篇关于 Vue 表情包输入组件的使用方法与封装指南的文章。通过安装依赖、全局注册和局部使用,可以快速集成表情包功能到 Vue 项目中。文章还详细介绍了组件的封装实现、高级配置(如自定义表情列表、主题定制、动画效果和懒加载)以及完整集成示例。开发者可根据需求扩展功能,例如 GIF 搜索或自定义表情上传,提升用户体验。资源链接提供进一步学习材料。
771 1
|
存储 前端开发 JavaScript
为什么我不再用Vue,改用React?
当我走进现代前端开发行业的时候,我做了一个每位开发人员都要做的决策:选择一个合适的框架。当时正逢 jQuery 被淘汰,前端开发者们不再用它编写难看的、非结构化的老式 JavaScript 程序了。
|
JavaScript
vue实现任务周期cron表达式选择组件
vue实现任务周期cron表达式选择组件
1452 4
|
12月前
|
JavaScript 数据可视化 前端开发
基于 Vue 与 D3 的可拖拽拓扑图技术方案及应用案例解析
本文介绍了基于Vue和D3实现可拖拽拓扑图的技术方案与应用实例。通过Vue构建用户界面和交互逻辑,结合D3强大的数据可视化能力,实现了力导向布局、节点拖拽、交互事件等功能。文章详细讲解了数据模型设计、拖拽功能实现、组件封装及高级扩展(如节点类型定制、连接样式优化等),并提供了性能优化方案以应对大数据量场景。最终,展示了基础网络拓扑、实时更新拓扑等应用实例,为开发者提供了一套完整的实现思路和实践经验。
1673 78