Vue自定义指令之根据权限控制显示隐藏指令,自定义指令全局注册和局部注册

  • vue自定义指令之根据权限控制显示隐藏指令
  • vue自定义指令全局注册和局部注册
  • 指令生命周期

根据权限控制显示隐藏指令

首先要在==src/directives/==文件夹下新建一个power.js文件:

let authList = ['save','edit',......] // 可访问的权限列表

const power = {
  // 指令的定义
  inserted: function (el, binding) {
    if (!binding.value) { return }
    let value = `${binding.value}`
    if (!authList.includes(value)) {
      el.parentNode && el.parentNode.removeChild(el)
    }
  }
}

export default power

然后在要使用该指令的地方引入指令:

import {power} from ‘@/directives/power.js’

在组件内部注册指令:

directives: { power },

computed: {…

最后在要控制该权限的组件代码上绑定该指令:

<el-button v-power="'save'" type="primary" plain @click="save">保存</el-button>

— 补充:

如果要全局注册指令可以用:

Vue.directive('focus', {
  	// el为dom元素
  	inserted: function (el) {
    	// 自动获取元素焦点
    	el.focus();
 	}
});

自定义指令生命周期:

  • bind: function (el, binding, vnode) {
    el.style[‘color’] = binding.value
    }, // 只调用一次,指令第一次绑定到元素时候调用,用这个钩子可以定义一个绑定时执行一次的初始化动作。
  • inserted: function () {}, // 被绑定的元素插入父节点的时候调用(父节点存在即可调用,不必存在document中)
  • update: function () {}, // 被绑定与元素所在模板更新时调用,而且无论绑定值是否有变化,通过比较更新前后的绑定值,忽略不必要的模板更新
  • componentUpdated: function () {}, // 被绑定的元素所在模板完成一次更新更新周期的时候调用
  • unbind: function () {} // 只调用一次,指令元素解绑的时候调用
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值