欢迎来到代码驿站!

vue

当前位置:首页 > 网页前端 > vue

vue使用自定义指令实现按钮权限展示功能

时间:2022-12-05 12:53:14|栏目:vue|点击:

一、在src下新建directive文件夹

二、定义index.js文件,在vue上注入自定义指令

import hasBtn from './permission/hasBtn'
const install = function (Vue) {
      Vue.directive('hasBtn', hasBtn)
}
if (window.Vue) {
      window['hasBtn'] = hasBtn
      Vue.use(install); // eslint-disable-line
}
export default install
 

三、编写自定义指令

hasBtn.js文件

/**
 * 设置操作权限标识符
 */
export default {
      inserted(el, binding, vnode) {
            /** 从binding中获取dom元素的value值 */
            const { value } = binding
            /** 存放value值 */
            const btn_permission = value;
            /** 拿到所有具备权限按钮的集合,通过传入的按钮id进行匹配 */
            const permissions = JSON.parse(sessionStorage.getItem('btnarr'))
            /** 利用some查询,只要有一个元素满足条件就返回true,全部不满足返回false */
            var hasPermissions = permissions.some(permission => {
                  return btn_permission == permission.menuId
            })
            /** 传入的按钮id不存在集合里面就移除该节点 */
            if (!hasPermissions) {
                  el.parentNode && el.parentNode.removeChild(el)
            }
      }
}

四、使用

例如在一个vue页面里面的一个新增按钮加上v-hasBtn属性

<el-button  v-hasBtn="15" type="primary" icon="el-icon-plus" size="mini" @click="addRelease">新增</el-button>

直接传入该按钮的id,即 v-hasBtn="15",vue的自定义指令都是用v-开头即可,此时就可以触发自定义指令定义的函数,达到按钮权限可控的目的。

上一篇:VUE搭建分布式医疗挂号系统的前台预约挂号步骤详情

栏    目:vue

下一篇:一文了解axios和vue的整合操作

本文标题:vue使用自定义指令实现按钮权限展示功能

本文地址:http://www.codeinn.net/misctech/220595.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有