[ 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 高级表单中,经常用到的几种表单项格式验证了。


[1] 原文阅读

我是 Just,听说长的好看的都关注 订阅号[ 设计师工作日常 ] 了!skr~ skr~

  • 26
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

设计师工作日常

请我炫个饼🫓

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

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

打赏作者

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

抵扣说明:

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

余额充值