Yve*_*ves 16 vuejs2 vuejs-directive
我正在写一个自定义指令.
我希望它能像v-if它一样工作,但它内部会有一点逻辑.让我用一个例子来解释一下:
<button v-permission="PermissionFoo">Do Foo</button>
Run Code Online (Sandbox Code Playgroud)
它将检查权限并显示或隐藏组件.
目前我通过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);
}
}
Run Code Online (Sandbox Code Playgroud)
但我不希望这个元素留在文档中.所以我正在寻找除CSS以外的其他方式,因为它必须也像DOM一样从DOM中删除v-if.
Ser*_*nko 15
尝试使用这个hack:
Vue.directive('permission', (el, binding, vnode) => {
if (!isUserGranted(binding.value)) {
// replace HTMLElement with comment node
const comment = document.createComment(' ');
Object.defineProperty(comment, 'setAttribute', {
value: () => undefined,
});
vnode.elm = comment;
vnode.text = ' ';
vnode.isComment = true;
vnode.context = undefined;
vnode.tag = undefined;
vnode.data.directives = undefined;
if (vnode.componentInstance) {
vnode.componentInstance.$el = comment;
}
if (el.parentNode) {
el.parentNode.replaceChild(comment, el);
}
}
});
Run Code Online (Sandbox Code Playgroud)
UPD 05-19-2017:我的最新代码.我在使用html元素和Vue组件时定义setAttribute()并检查vnode.componentInstance以防止js错误.
| 归档时间: |
|
| 查看次数: |
3476 次 |
| 最近记录: |