antD 中常用的几种表单格式验证,用的 ProFrom 高级表单组件,主要看表单格式验证的部分,同 From 表单大同小异。
required: boolean 是否为必选字段
<ProFormText
name="title"
label="标题"
placeholder="请输入标题"
rules={[
{required: true, message: '标题不能为空'}
]}
/>
string 类型为字符串最大长度;number 类型时为最大值;array 类型时为数组最大长度
<ProFormText
name="brief"
label="摘要内容"
placeholder="请输入摘要内容"
rules={[
{required: true, message: '摘要内容不能为空'},
{max: 150,message: '摘要内容不能超过150个字符',}
]}
/>
string 类型为字符串最小长度;number 类型时为最小值;array 类型时为数组最小长度
<ProFormText
name="keyWord"
label="关键词"
placeholder="关键词"
rules={[
{required: true, message: '关键词不能为空'},
{min: 4,message: '关键词不能少于4个字符',}
]}
/>
<ProFormText
name="creatPaper"
label="创建人"
placeholder="请输入创建人姓名"
rules={[
{required: true, message: '创建人姓名不能为空'},
{min: 2,message: '创建人姓名不能少于2个字符',},
{max: 20,message: '创建人姓名不能超过20个字符',}
]}
/>
whitespace: boolean 如果字段仅包含空格则校验不通过
<ProFormText
name="majors"
label="大学专业"
placeholder="请输入专业"
rules={[
{required: true, message: '专业不能为空'},
{whitespace: true,message: '仅输入空格无效'}
]}
/>
自定义校验,接收 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~