一个类似于vuejs中的v-if的自定义指令

时间:2017-03-24 15:54:11

标签: vuejs2 vuejs-directive

我正在写一个自定义指令。

我希望它像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中删除。

1 个答案:

答案 0 :(得分:10)

尝试使用此黑客:

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);
    }
  }
});

UPD 05-19-2017 :我的最新代码。我定义setAttribute()并检查vnode.componentInstance以防止在使用html元素和Vue组件时出现js错误。