【发布时间】:2017-08-17 15:44:45
【问题描述】:
我正在 vue 中编写自定义指令。
我希望它像v-if 一样工作,但它内部会有一点逻辑。让我用一个例子来解释:
<button v-permission="PermissionFoo">Do Foo</button>
它会检查权限并显示或隐藏组件。
目前我正在通过 CSS 样式执行此操作:
var processPermissionDirective = function (el, binding, vnode) {
if (SOME_LOGIC_HERE) {
el.style.display = el._display;
}
else {
el.style.display = 'none';
}
}
export default {
bind: function (el, binding, vnode) {
el._display = el.style.display;
processPermissionDirective(el, binding, vnode);
},
update: function (el, binding, vnode) {
processPermissionDirective(el, binding, vnode);
}
}
但我不希望这个元素留在文档中。所以我正在寻找 CSS 以外的另一种方式,因为它也必须像 v-if 那样从 DOM 中删除。
【问题讨论】:
标签: vuejs2 vue-directives