ant design-form表单的自定义校验validator

  • 在form表单的使用中,我们经常是使用rules属性进行简单输入文本验证,常见的使用模式如下:rules={[{ required: true, message: ‘’ }
<Form
  name="basic"
    ref={ref}
    labelCol={{
      span: 4,
    }}
    wrapperCol={{
      span: 16,
    }}
  >
    <Form.Item
      label="password"
      name="password"
      rules={[{ required: true, message: 'xxxx' }  >
      <Input />
    </Form.Item>
  </Form>
  • 仅使用rules={[{ required: true, message: ‘xxxx’ ‘’ }模式只能简单验证输入用户是否输入文本,不能动态判断用户是否输入指定规则数据
  • antd的form的rules支持validator方式添加自定义校验,通过接收 Promise 作为返回值,Promise.reject(‘验证不通过提示信息’),Promise.resloce()通过验证
  • 一个简单的用户密码自定义校验如下
import React, { useRef } from 'react';
import ReactDOM from 'react-dom';
import 'antd/dist/antd.css';
import './index.css';
import { Form, Input, Button, Checkbox } from 'antd';

const Demo = () => {
  const ref = useRef();
  const onFinish = (values) => {
    console.log('Success:', values);
  };

  const onFinishFailed = (errorInfo) => {
    console.log('Failed:', errorInfo);
  };

  const changName = (errorInfo) => {
    // 获取表格数据
    const formData = ref.current.getFieldsValue();
    // 动态判断输入文本是否符合检验条件
    // 长度为8-18位数
    if (formData.password.length < 8 || formData.password.length > 18) {
      return Promise.reject('请输入8-18位密码')
    }
    const reg = /^((?=.*\d)(?=.*[a-z])(?=.*[A-Z])|(?=.*\d)(?=.*[A-Z])(?=.*[_!@#$%^&*()?=\[\]])|(?=.*\d)(?=.*[a-z])(?=.*[_!@#$%^&*()?=\[\]])|(?=.*[A-Z])(?=.*[a-z])(?=.*[_!@#$%^&*()?=\[\]])).{8,18}$/
    const flag = reg.test(formData.password)
    if (!flag) {
      return Promise.reject('数字、大写字母、小写字母、特殊字符至少3种, 特殊字符仅限于:_!@#$%^&*()?=[]')
    }
    // 通过验证
    return Promise.resolve()
  };

  return (
    <Form
      name="basic"
      ref={ref}
      labelCol={{
        span: 4,
      }}
      wrapperCol={{
        span: 16,
      }}
    >
      <Form.Item
        label="password"
        name="password"
        rules={[{ required: true, message: '' }, { validator: changName }]}      >
        <Input />
      </Form.Item>
    </Form>
  );
};

ReactDOM.render(<Demo />, document.getElementById('container'));

在这里插入图片描述
在这里插入图片描述

  • form表单的校验默认方式为onChange事件触发,但是有时候,交互体验师会希望用户输入过程中不要动态校验,而是希望在input失焦事件后才进行校验,这时候需要配置Form.Item的validateTrigger属性,统一设置字段触发验证的时机,默认值为onChange,将其设置为onBlur即可
import React, { useRef } from 'react';
import ReactDOM from 'react-dom';
import 'antd/dist/antd.css';
import './index.css';
import { Form, Input, Button, Checkbox } from 'antd';

const Demo = () => {
  const ref = useRef();
  const onFinish = (values) => {
    console.log('Success:', values);
  };

  const onFinishFailed = (errorInfo) => {
    console.log('Failed:', errorInfo);
  };

  const changName = (errorInfo) => {
    // 获取表格数据
    const formData = ref.current.getFieldsValue();
    // 动态判断输入文本是否符合检验条件
    // 长度为8-18位数
    if (formData.password.length < 8 || formData.password.length > 18) {
      return Promise.reject('请输入8-18位密码');
    }
    const reg =
      /^((?=.*\d)(?=.*[a-z])(?=.*[A-Z])|(?=.*\d)(?=.*[A-Z])(?=.*[_!@#$%^&*()?=\[\]])|(?=.*\d)(?=.*[a-z])(?=.*[_!@#$%^&*()?=\[\]])|(?=.*[A-Z])(?=.*[a-z])(?=.*[_!@#$%^&*()?=\[\]])).{8,18}$/;
    const flag = reg.test(formData.password);
    if (!flag) {
      return Promise.reject(
        '数字、大写字母、小写字母、特殊字符至少3种, 特殊字符仅限于:_!@#$%^&*()?=[]'
      );
    }
    // 通过验证
    return Promise.resolve();
  };

  return (
    <Form
      name="basic"
      ref={ref}
      labelCol={{
        span: 4,
      }}
      wrapperCol={{
        span: 16,
      }}
    >
      <Form.Item
        label="password"
        name="password"
        validateTrigger="onBlur"
        rules={[{ required: true, message: '' }, { validator: changName }]}
      >
        <Input />
      </Form.Item>
    </Form>
  );
};

ReactDOM.render(<Demo />, document.getElementById('container'));

在这里插入图片描述
在这里插入图片描述

  • 4
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
对于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实现表单自定义校验规则的方法。你可以根据自己的需要编写更复杂的校验逻辑,并在自定义校验器函数中进行处理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值