[ React+ant Design] ProFrom高级表单 - 基本的几种格式验证

时间:2021-10-27 00:58:17

[ React+ant Design] ProFrom高级表单 - 基本的几种格式验证


antD 中常用的几种表单格式验证,用的 ProFrom 高级表单组件,主要看表单格式验证的部分,同 From 表单大同小异。

下面就是基本的几种格式验证:

1、不能为空

required: boolean 是否为必选字段

<ProFormText
  name="title"
  label="标题"
  placeholder="请输入标题"
  rules={[
    {required: true, message: '标题不能为空'}
  ]}
/>

2、( pattern ) 正则表达式匹配,限制输入为数字

<ProFormText
  name="order"
  label="序号"
  placeholder="请输入序号"
  rules={[
    {required: true, message: '序号不能为空'},
    {pattern: /^[0-9]+$/,message: '序号只能输入数字'}
  ]}
/>

3、( max ) 限制字符长度

string 类型为字符串最大长度;number 类型时为最大值;array 类型时为数组最大长度

<ProFormText
  name="brief"
  label="摘要内容"
  placeholder="请输入摘要内容"
  rules={[
    {required: true, message: '摘要内容不能为空'},
    {max: 150,message: '摘要内容不能超过150个字符',}
  ]}
/>

4、( min ) 字符最小长度

string 类型为字符串最小长度;number 类型时为最小值;array 类型时为数组最小长度

<ProFormText
  name="keyWord"
  label="关键词"
  placeholder="关键词"
  rules={[
    {required: true, message: '关键词不能为空'},
    {min: 4,message: '关键词不能少于4个字符',}
  ]}
/>

5、( min、max ) 组合使用,限制字符长度范围

<ProFormText
  name="creatPaper"
  label="创建人"
  placeholder="请输入创建人姓名"
  rules={[
    {required: true, message: '创建人姓名不能为空'},
    {min: 2,message: '创建人姓名不能少于2个字符',},
    {max: 20,message: '创建人姓名不能超过20个字符',}
  ]}
/>

6、( whitespace ) 组合使用,限制字符长度范围

whitespace: boolean 如果字段仅包含空格则校验不通过

<ProFormText
  name="majors"
  label="大学专业"
  placeholder="请输入专业"
  rules={[
    {required: true, message: '专业不能为空'},
    {whitespace: true,message: '仅输入空格无效'}
  ]}
/>

7、( validator ) 自定义校验

自定义校验,接收 Promise 作为返回值,(rule, value) => Promise

<ProFormText
  name="creatPaper"
  label="年龄"
  placeholder="请输入年龄"
  rules={[
    {required: true, message: '年龄不能为空'},
    {validator: numberCheck}
  ]}
/>
<script>
// 自定义校验,输入正整数,且大于0
const numberCheck = (rule, value, callback) => {
  if (value % 1 !== 0 || value <= 0) {
    callback('请输入正整数,且大于0')
  }
  callback(); // 必须返回一个callback
}
</script>

以上就是在 React ProFrom 高级表单中,经常用到的几种表单项格式验证了。