rsuite-schema
rsuite-schema
是一个数据建模及数据验证工具
版本与状态
安装
npm i rsuite-schema --save
// 或者
yarn add rsuite-schema
示例
import { SchemaModel, StringType, DateType, NumberType } from 'rsuite-schema';
const userModel = SchemaModel({
username: StringType().isRequired('用户名不能为空'),
email: StringType().isEmail('请输入正确的邮箱'),
age: NumberType('年龄应该是一个数字').range(18, 30, '年应该在 18 到 30 岁')
});
const checkResult = userModel.check({
username: 'foobar',
email: 'foo@bar.com',
age: 40
})
console.log(checkResult);
checkResult
返回结构是:
{
username: { hasError: false },
email: { hasError: false },
age: { hasError: true, errorMessage: '年应该在 18 到 30 岁' }
}
多重验证
StringType()
.minLength(6,'不能少于 6 个字符')
.maxLength(30,'不能大于 30 个字符')
.isRequired('该字段不能为空');
自定义验证
通过 addRule
函数自定义一个规则。
如果是对一个字符串类型的数据进行验证,可以通过 pattern
方法设置一个正则表达式进行自定义验证。
const myModel = SchemaModel({
field1: StringType().addRule((value) => {
return /^[1-9][0-9]{3}\s?[a-zA-Z]{2}$/.test(value);
}, '请输入合法字符'),
field2: StringType().pattern(/^[1-9][0-9]{3}\s?[a-zA-Z]{2}$/, '请输入合法字符')
});
自定义动态错误信息
例如,要通过 value
的不同情况,返回不同的错误信息,参考以下
const myModel = SchemaModel({
field1: StringType().addRule((value) => {
if(value==='root'){
return {
hasError: true,
errorMessage:'不能是关键字 root'
}
}else if(!/^[a-zA-Z]+$/.test(value)){
return {
hasError: true,
errorMessage:'只能是英文字符'
}
}
return {
hasError: false
}
})
});
API
StringType
StringType().isRequired('该字段不能为空');
- isEmail(String: errorMessage)
StringType().isEmail('请输入正确的邮箱地址');
- isURL(String: errorMessage)
StringType().isURL('请输入正确的URL地址');
- isOneOf(Array: items, String: errorMessage)
StringType().isOneOf(['Javascript','CSS'],'只能输入 `Javascript`和 `CSS`');
- containsLetter(String: errorMessage)
StringType().containsLetter('必须包含英文字符');
- containsUppercaseLetter(String: errorMessage)
StringType().containsUppercaseLetter('必须包含大写的英文字符');
- containsLowercaseLetter(String: errorMessage)
StringType().containsLowercaseLetter('必须包含小写的英文字符');
- containsLetterOnly(String: errorMessage)
StringType().containsLetterOnly('只能包含的英文字符');
- containsNumber(String: errorMessage)
StringType().containsNumber('必须包含数字');
- pattern(Object: regexp, String: errorMessage)
StringType().pattern(/^[1-9][0-9]{3}\s?[a-zA-Z]{2}$/, '请输入合法字符')
- rangeLength(Number: minLength, Number: maxLength, String: errorMessage)
StringType().rangeLength(6, 30, '字符个数只能在 6 - 30 之间')
- minLength(Number: minLength, String: errorMessage)
StringType().minLength(6, '最小需要6个字符')
- maxLength(Number: maxLength, String: errorMessage)
StringType().minLength(30, '最大只能30个字符')
- addRule(Function: onValid, String: errorMessage)
StringType().addRule((value) => {
return /^[1-9][0-9]{3}\s?[a-zA-Z]{2}$/.test(value);
}, '请输入合法字符')
NumbserType
NumbserType().isRequired('该字段必填')
- isInteger(String: errorMessage)
NumbserType().isInteger('只能是整型')
- isOneOf(Array: items, String: errorMessage)
NumbserType().isOneOf([5,10,15],'只能是`5`,`10`,`15`')
- pattern(Object: regexp, String: errorMessage)
NumbserType().pattern(/^[1-9][0-9]{3}$/, '请输入合法字符')
- range(Number: minLength, Number: maxLength, String: errorMessage)
NumbserType().range(18, 40, '请输入 18 - 40 之间的数字')
- min(Number: min, String: errorMessage)
NumbserType().min(18, '最小值 18')
- max(Number: min, String: errorMessage)
NumbserType().max(40, '最大值 40')
- addRule(Function: onValid, String: errorMessage)
NumbserType().addRule((value) => {
return value % 5 ===0;
}, '请输入有效的数字')
ArrayType
ArrayType().isRequired('该字段必填')
- rangeLength(Number: minLength, Number: maxLength, String: errorMessage)
ArrayType().rangeLength(1, 3, '至少选择1个,但不能超过3个')
- minLength(Number: minLength, String: errorMessage)
ArrayType().minLength(1, '至少选择1个')
- maxLength(Number: maxLength, String: errorMessage)
ArrayType().maxLength(3, '不能超过3个')
- unrepeatable(String: errorMessage)
ArrayType().unrepeatable('不能出现重复选项')
- of(Object: type, String: errorMessage)
ArrayType().of(StringType().isEmail(), '格式错误');
- addRule(Function: onValid, String: errorMessage)
ArrayType().addRule((value) => {
return value.length % 2 ===0;
}, '好事成双')
DateType
DateType().isRequired('日期不能为空');
- range(Date: min, Date: max, String: errorMessage)
DateType().range(
new Date('08/01/2017'),
new Date('08/30/2017'),
'时间应该在 08/01/2017 - 08/30/2017 之间'
);
- min(Date: min, String: errorMessage)
DateType().min(
new Date('08/01/2017'),
'时间的最小值 08/01/2017'
);
- max(Date: max, String: errorMessage)
DateType().max(
new Date('08/30/2017'),
'时间的最大值 08/30/2017'
);
- addRule(Function: onValid, String: errorMessage)
DateType().addRule((value) => {
return value.getDay()===2;
}, '只能选择周二')
ObjectType
ObjectType().isRequired('该对象不能为空');
ObjectType().shape({
email: StringType().isEmail('应该是一个 email'),
age: NumberType().min(18, '年龄应该大于18岁')
})
- addRule(Function: onValid, String: errorMessage)
ObjectType().addRule((value) => {
if(value.id || value.email){
return true;
}
return false;
}, 'id 与 email 必须有一个不能为空')
BooleanType
BooleanType().isRequired('该字段不能为空');
- addRule(Function: onValid, String: errorMessage)
ObjectType().addRule((value) => {
if(typeof value === 'undefined' && A === 10){
return false;
}
return true;
}, '当 A 等于 10 的时候,该值必须为空');