小demo示例:
<template>
<el-form :model="form" :rules="rules" ref="formRef">
<el-form-item prop="username" label="姓名:">
<el-input v-model="form.username"></el-input>
</el-form-item>
<el-form-item prop="idCard" label="证件号码:">
<el-input type="password" v-model="form.idCard"></el-input>
</el-form-item>
<el-form-item>
<el-button type="primary" @click="submitForm">提交</el-button>
<el-button type="primary" @click="resetForm">取消</el-button>
</el-form-item>
</el-form>
</template>
<script setup>
import { ref } from 'vue';
const form = ref({
username: '',
idCard: ''
});
const rules = {
username: [
{ required: true, message: '请输入姓名', trigger: 'blur' }
],
idCard: [
{ required: true, message: '请输入证件号码'},
{
pattern: /(^[1-9]\d{5}(18|19|([23]\d))\d{2}((0[1-9])|(10|11|12))(([0-2][1-9])|10|20|30|31)\d{3}[0-9Xx]$)|(^[1-9]\d{5}\d{2}((0[1-9])|(10|11|12))(([0-2][1-9])|10|20|30|31)\d{2}$)/,
message: '请输入正确格式!',
trigger: 'blur'
}
]
};
const formRef = ref(null);
const submitForm = () => {
formRef.value.validate((valid) => {
if (valid) {
console.log('submit!')
} else {
return false;
}
});
}
const resetForm = () => {
formRef.value.resetFields()
}
</script>