ant design vue自定义表单验证不生效和自定义校验内容有值后自动清除警告的方法

18 篇文章 1 订阅
1 篇文章 0 订阅

前置-先来看看下面预期效果是什么

  • 当我们点击提交表单的时候,下面的输出结果是什么?红色*代表必填字段

  • 很明显你可能会角色在**测试这一行当中会提示信息,**但是却不会

问题原因及解决

  • 在使用ant - design vue的表单验证的时候,如果不填写name属性,那么最后校验的时候是不会进行校验的
<!--不进行校验,缺少name-->
<a-form-item label="测试"  :rules="[{ required: true, message: '测试不能为空', whitespace: true },]">
    <div style="position: relative;display: inline-block">
        <a-input v-model:value="dataForm.name" :maxlength="20" style="width: 500px;" placeholder="请输入" />
     </div>
</a-form-item>
  • 所以老老实实加上name属性吧
<!--加上name就会校验了-->
<a-form-item label="测试" name="name" :rules="[{ required: true, message: '测试不能为空', whitespace: true },]">
    <div style="position: relative;display: inline-block">
        <a-input v-model:value="dataForm.name" :maxlength="20" style="width: 500px;" placeholder="请输入" />
     </div>
</a-form-item>

值得一提

  • 有时候我们使用了自定义规则校验,无论是trigger:change还是trigger:blur,但数据更新后,都无法将警告提示进行自动更改

  • 从而如果有警告提示信息,尽管用户在之后输入了新值,也依旧会有报错,那么要怎么解决呢?

    • 很简单<a-form-item></a-form-item>添加ref,调用ref当中的clearValidate即可
  • 示例

  <a-form-item ref="groupChat" label="选择群聊" name="chatId" :rules="[{required:true,trigger:'change',validator:validatorChatGroup}]">
              <SelectChatGroup :corpId="$route.query?.corpId ?? null" v-model="dataForm.chatId.chatIds" />
              <SelectedChatGroupList v-if=" dataForm.chatId.chatIds.length" v-model="dataForm.chatId.chatIds"/>
</a-form-item>

//对自定义属性进行监视,当有值的时候就调用里面的方法进行清除提示
watch:{
    'dataForm.chatId.chatIds':{
        handler(){
            this.$refs.groupChat.clearValidate();
        },
    }
},

  • 6
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
对于ant-design-vue表单自定义校验规则,你可以使用Vue的"自定义校验器"来实现。下面是一个简单的示例: 1. 首先,你需要在Vue组件中定义一个自定义校验器函数,该函数接收两个参数:rule和value。rule是当前校验规则的配置,value是当前表单字段的值。校验器函数需要返回一个Promise对象,通过resolve()来表示校验通过,通过reject()来表示校验失败。 ```javascript // 导入所需的校验规则 import { ValidationRule } from 'ant-design-vue/es/form/Form'; // 定义校验器函数 const customValidator = (rule, value) => { return new Promise((resolve, reject) => { // 自定义校验逻辑 if (value === 'custom') { resolve(); } else { reject(new Error('输入值不合法')); } }); }; ``` 2. 在表单项的rules属性中使用自定义校验器函数。rules属性是一个数组,可以包含多个校验规则。在自定义校验规则中,你可以使用ValidationRule对象提供的方法来定义校验规则的其他配置。 ```javascript <template> <a-form :form="form"> <a-form-item label="自定义校验"> <a-input v-decorator="['customField', { rules: [{ validator: customValidator }] }]"></a-input> </a-form-item> <!-- 其他表单项 --> <!-- ... --> </a-form> </template> <script> export default { data() { return { form: this.$form.createForm(this), }; }, }; </script> ``` 这样,当用户输入的值不等于'custom'时,校验器函数将返回一个带有错误信息的Promise对象,从而触发表单项的校验错误提示。 以上就是使用ant-design-vue实现表单自定义校验规则的方法。你可以根据自己的需要编写更复杂的校验逻辑,并在自定义校验器函数中进行处理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

未成年梦想

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值