validateRules: { certno: [ { required: true, message: '证件号码不能为空' }, { validator: (rule, value, callback) => { const result = verify(value) if (result.status === 0) { callback() } else { callback(new Error(result.msg)) } }, message: '请输入正确的身份证号码' } ], name: [ { required: true, message: '姓名不可为空' } ], empName: [ { required: true, message: '单位名称不可为空' } ], empCode: [ { required: true, message: '统一信用代码不能为空' } ], reason: [ { required: true, message: '失信原因不能为空' } ] } 中如何加入 单位统一信用代码 校验规则?
时间: 2024-02-10 07:20:11 浏览: 26
要加入单位统一信用代码的校验规则,可以在 validateRules 对象中的 empCode 字段中加入校验规则,例如:
```
empCode: [
{ required: true, message: '统一信用代码不能为空' },
{ pattern: /^[A-Z0-9]{18}$/, message: '请输入正确的统一信用代码' }
]
```
其中,pattern 规则用于对统一信用代码进行正则表达式校验,要求输入的字符串必须符合 /^[A-Z0-9]{18}$/ 的格式,即必须是 18 位由大写字母和数字组成的字符串。
这样,在进行表单验证时,就会对 empCode 字段进行必填和格式校验,确保用户输入的统一信用代码符合规范。
相关问题
validateRules: { certno: [ { required: true, message: '证件号码不能为空' } ], name: [ { required: true, message: '姓名不可为空' } ], empName: [ { required: true, message: '单位名称不可为空' } ], empCode: [ { required: true, message: '统一信用代码不能为空' } ], reason: [ { required: true, message: '失信原因不能为空' } ] } 中如何加入证件号码校验规则?
在`validateRules`中加入证件号码校验规则,可以在`certno`数组中新增一个对象,如下所示:
```javascript
validateRules: {
certno: [
{
required: true,
message: '证件号码不能为空'
},
{
validator: (rule, value, callback) => {
const reg = /^(\d{15}$|^\d{18}$|^\d{17}(\d|X|x))$/
if (!reg.test(value)) {
callback(new Error('请输入正确的身份证号码'))
} else {
callback()
}
},
message: '请输入正确的身份证号码'
}
],
name: [
{
required: true,
message: '姓名不可为空'
}
],
empName: [
{
required: true,
message: '单位名称不可为空'
}
],
empCode: [
{
required: true,
message: '统一信用代码不能为空'
}
],
reason: [
{
required: true,
message: '失信原因不能为空'
}
]
}
```
在上面的代码中,我们在`certno`数组中新增了一个对象,其中`validator`属性是一个函数,用于自定义校验规则。在该函数中,我们使用正则表达式验证传入的证件号码是否符合规则,如果不符合规则,通过`callback`函数返回一个`Error`对象,提示用户输入正确的身份证号码。如果输入的身份证号码符合规则,则直接调用`callback`函数即可。最后,将这个新对象的`message`属性设置为相应的提示信息即可。
validateRules: { certno: [ { required: true, message: '证件号码不能为空' }, { validator: (rule, value, callback) => { const result = verify(value) if (result.status === 0) { callback() } else { callback(new Error(result.msg)) } }, message: '请输入正确的身份证号码' } ], name: [ { required: true, message: '姓名不可为空' } ], empName: [ { required: true, message: '单位名称不可为空' } ], empCode: [ { required: true, message: '统一信用代码不能为空' } ], reason: [ { required: true, message: '失信原因不能为空' } ] } 改用 Promise 写
好的,您可以将 `validator` 中的 `callback` 改为返回 `Promise`,如下所示:
```javascript
validateRules: {
certno: [
{ required: true, message: '证件号码不能为空' },
{
validator: (rule, value) => {
return new Promise((resolve, reject) => {
const result = verify(value);
if (result.status === 0) {
resolve();
} else {
reject(new Error(result.msg));
}
});
},
message: '请输入正确的身份证号码',
},
],
name: [
{
required: true,
message: '姓名不可为空',
},
],
empName: [
{
required: true,
message: '单位名称不可为空',
},
],
empCode: [
{
required: true,
message: '统一信用代码不能为空',
},
],
reason: [
{
required: true,
message: '失信原因不能为空',
},
],
};
```
这里使用了 `Promise` 对象封装异步验证逻辑,`resolve()` 表示验证通过,`reject()` 表示验证失败并返回错误信息。这样,您就可以像下面这样使用 `async/await` 或者 `.then()` 处理验证结果:
```javascript
// 使用 async/await 处理表单验证
async function handleSubmit() {
try {
await form.validateFields();
// 表单验证通过
} catch (error) {
// 表单验证失败
}
}
// 使用 .then() 处理表单验证
form
.validateFields()
.then(() => {
// 表单验证通过
})
.catch((error) => {
// 表单验证失败
});
```