在开源项目低代码表单FormCreate 中,可以通过 validate 配置项为表单组件设置验证规则。无论是内置的表单组件还是自定义的表单组件,都支持表单校验。本文将详细介绍验证规则的使用方法,并提供一些示例来帮助您更好地理解和应用这些功能。
基本验证规则
validate
配置项允许您为每个表单字段定义多种验证规则。每个规则都是一个对象,您可以通过设置不同的属性来控制验证行为。
参数 | 说明 | 类型 | 默认值 |
---|---|---|---|
enum | 枚举类型 | string | - |
len | 字段长度 | number | - |
max | 最大长度 | number | - |
message | 校验文案 | string | - |
min | 最小长度 | number | - |
pattern | 正则表达式校验 | RegExp | - |
required | 是否必选 | boolean | false |
transform | 校验前转换字段值 | function(value) => transformedValue:any | - |
type | 内建校验类型,可选项 | string | 'string' |
validator | 自定义校验 | function(rule, value, callback) | - |
whitespace | 必选时,空格是否会被视为错误 | boolean | false |
type 需要根据组件的 value 类型定义
常见校验示例
1.必填字段校验
js
{
type: 'input',
field: 'username',
title: '用户名',
validate: [
{ required: true, message: '用户名是必填项' }
]
}
2.最小长度校验
js
{
type: 'input',
field: 'password',
title: '密码',
validate: [
{ required: true, min: 6, message: '密码长度不能少于6个字符' }
]
}
3. 正则表达式校验
js
{
type: 'input',
field: 'phone',
title: '电话号码',
validate: [
{ required: true, message: '请输入电话号码' },
{ pattern: '^1[3-9]\d{9}$', message: '请输入有效的手机号' }
]
}
4. 自定义校验
js
{
type: 'input',
field: 'age',
title: '年龄',
validate: [
{
validator: (rule, value, callback) => {
if (value < 18) {
callback(new Error('年龄必须大于或等于18岁'));
} else {
callback();
}
},
message: '请输入合法的年龄'
}
]
}
5. 枚举值校验
js
{
type: 'select',
field: 'role',
title: '角色',
validate: [
{ required: true, message: '请选择角色' },
{ enum: ['admin', 'user', 'guest'], message: '角色必须是admin, user, 或guest' }
],
options: [
{ label: '管理员', value: 'admin' },
{ label: '用户', value: 'user' },
{ label: '游客', value: 'guest' }
]
}
利用本文中的示例和 async-validator 的文档,您可以快速实现各种校验需求,为用户提供更好的表单交互体验。