Vue-validator 如何做统一的验证

发布于 2022-09-04 09:57:31 字数 786 浏览 30 评论 0

  1. 使用 vue-validator 封装好一个带验证的input组件, 由父组件传递验证规则,

  2. 现在, 我需要在页面点击提交的时候对结果进行验证, 验证失败的组件显示相应的提示.

  3. 请问: 我要如何在页面中触发子组件的验证事件.

//my-input.vue
<validity :validators="validators">
  <input type="text" :value="value" @focusout="handlerValidate">
  <span v-for="error in result.errors">{{error.message}}</p>
</validity>
handlerValidate (event) {
  let $validity = event.target.$validity;

  $validity.validate(() => {
    this.result = $validity.result;
  });
}
// home.vue
<my-form>
  <item>
    <my-input v-model="username" :validators="validators"></my-input>
  </item>
  <item>
    <button>验证</button>
  </item>
</my-form>

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

眼眸里的快感 2022-09-11 09:57:31

楼主需要的可能是这个吧:
验证目标表单元素
https://github.com/kazupon/vu...

methods: {
    onSubmit: function (e) {
      // validate the all fields manually with touched
      var self = this
      this.$validate(true, function () {
        console.log('validate done !!')
        if (self.$validation.invalid) {
          e.preventDefault()
        }
      })
    }
  }
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文