form表单数字校验(二)——邮箱校验-当前页面

form表单数字校验(二)——邮箱校验-当前页面

效果

在这里插入图片描述

代码

index.vue

<el-form-item v-if='!isDisabled' label='邮箱'>
    <el-input
        v-model.trim='ruleForm.email'
        class='n_form_is'
    
    ></el-input>
</el-form-item>
<el-form-item v-else label='邮箱'>
    {{ ruleForm.email }}
</el-form-item>

<script>
    setup(props, context) {
        // 当前页面数据
        
        const router = useRouter();
        const route = useRoute();
        const store = useStore();
        const isDisabled = computed(() => {
            return route.query.isDisabled == '1' ? false : true;
        });
        /*校验电话码格式 */
        const isTelCode = (rule, value, callback) => {
            const reg = /^1(3|4|5|6|7|8|9)\d{9}$/;
            if (!reg.test(value)) {
                callback(new Error('请输入正确的手机号'));
            } else {
                callback();
            }
        };
        // 邮箱
        const IsEmail = (rule, value, callback) => {
            const reg = /^([A-Za-z0-9_\-.])+@([A-Za-z0-9_\-.])+\.([A-Za-z]{2,4})$/;
            if (!reg.test(value)) {
                callback(new Error('请输入正确的邮箱'));
            } else {
                callback();
            }
        };
        // 正整数
        const isNumber = (rule, value, callback) => {
            if (regexRoles.isNumber(value) !== value) {
                callback(new Error('仅支持正整数'));
            } else {
                callback();
            }
        };    
    const state = reactive({
        ruleForm: {
            email: '',
        },
        rules: {
            email: [
                {
                    required: true,
                    message: '请输入邮箱信息',
                    trigger: 'blur'
                },
                // {
                //     max: 16,
                //     message: '最大16',
                //     trigger: 'blur'
                // },
                {
                    validator: IsEmail,
                    trigger: 'blur'
                }
            ], 
        }
    })
    
    //方法
    staffFile.getResumeDetail({ resumeId: route.query.resumeId })
                    .then(res => {
                        if (res.code === 200) {
                            state.ruleForm.email = res.data.email;
	         			}
                     })
</script>
el-formElement UI 提供的表单组件,用于快构建表单界面。el-form 表单校验是指对表单中的输入内容进行验证,确保用户输入的数据符合预期的格式和要求。 在 el-form 中进行表单校验时,可以通过设置 rules 属性来定义校验规则。每个表单项(el-form-item)可以设置 prop 属性来指定校验规则所对应的字段名。校验规则可以是一个数组,每个规则对象包含 validator 和 message 两个属性,validator 是一个函数,用于自定义校验逻辑,message 是校验失败时显示的错误提示信息。 以下是 el-form 表单校验的示例代码: ```html <template> <el-form :model="form" :rules="rules" ref="form"> <el-form-item label="用户名" prop="username"> <el-input v-model="form.username"></el-input> </el-form-item> <el-form-item label="密码" prop="password"> <el-input type="password" v-model="form.password"></el-input> </el-form-item> <el-form-item> <el-button type="primary" @click="submitForm">提交</el-button> </el-form-item> </el-form> </template> <script> export default { data() { return { form: { username: '', password: '' }, rules: { username: [ { required: true, message: '请输入用户名', trigger: 'blur' }, { min: 3, max: 10, message: '用户名长度在 3 到 10 个字符之间', trigger: 'blur' } ], password: [ { required: true, message: '请输入密码', trigger: 'blur' }, { min: 6, max: 20, message: '密码长度在 6 到 20 个字符之间', trigger: 'blur' } ] } }; }, methods: { submitForm() { this.$refs.form.validate(valid => { if (valid) { // 表单校验通过,提交表单 // TODO: 提交表单的逻辑 } else { // 表单校验不通过,显示错误信息 return false; } }); } } }; </script> ``` 在上述示例中,通过设置 rules 属性来定义了两个校验规则,分别对应用户名和密码字段。在 submitForm 方法中,通过调用 this.$refs.form.validate 方法来触发表单校验校验结果会通过回调函数的参数 valid 返回,如果 valid 为 true,则表示表单校验通过,可以提交表单;如果 valid 为 false,则表示表单校验不通过,需要显示错误信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值