侧边栏壁纸
博主头像
分享你我博主等级

行动起来,活在当下

  • 累计撰写 112 篇文章
  • 累计创建 13 个标签
  • 累计收到 0 条评论

目 录CONTENT

文章目录

vue 自定义全局指令

管理员
2020-11-24 / 0 评论 / 0 点赞 / 14 阅读 / 2725 字

main.js加入

// 注册一个全局自定义指令 `v-checkParam`
Vue.directive("checkParam", {
  // 当被绑定的元素插入到 DOM 中时……
  // eslint-disable-next-line no-unused-vars
  inserted: function(el, binding, vNode) {
    // eslint-disable-next-line no-unused-vars
    el.addEventListener("keyup", function(event) {
      // 首先去除已有样式
      el.className = el.className.replace("input-error", "").trim();
      // if (!event.keyCode) { // 加上这个判断就是在提交时,才会校验
      // 判断是否是否必填
      let isRequired = binding.value.required;
      if (isRequired) {
        if (!el.value || el.value === "") {
          el.className += " input-error";
        }
      }
      // }
    });
  }
});
// 注册一个全局自定义指令 `v-checkSubmit`
Vue.directive("checkSubmit", {
  // 当被绑定的元素插入到 DOM 中时……
  inserted: function(el, binding, vNode) {
    // eslint-disable-next-line no-unused-vars
    el.addEventListener("click", function(event) {
      let elements = document.getElementsByClassName("v-check");
      var evObj = document.createEvent("Event");
      evObj.initEvent("keyup", true, true);
      for (let element of elements) {
        element.dispatchEvent(evObj);
      }
      let errorInputs = document.getElementsByClassName("input-error");
      if (errorInputs.length === 0) {
        vNode.context.submit();
      }
    });
  }
});


0

评论区