vue表单验证(用户名、密码、身份证号、中文姓名、手机号、邮箱)

vue表单验证(用户名、密码、身份证号、中文姓名、手机号、邮箱)

new Vue({
    el: '#register',
    data: function() {
        // 验证邮箱
        let checkEmail = (rule, value, callback) => {
            const mailReg = /^([a-zA-Z0-9_-])+@([a-zA-Z0-9_-])+(.[a-zA-Z0-9_-])+/
            if (!value) {
                return callback(new Error('请输入电子邮箱'))
            }
            if (mailReg.test(value)) {
                callback()
            } else {
                callback(new Error('请输入正确的邮箱格式'))
            }
        }
        // 验证手机号
        let checkPhone = (rule, value, callback) => {
            const phoneReg = /^1[34578]\d{9}$/
            if (!value) {
                return callback(new Error('请输入手机号码'))
            }
            if (phoneReg.test(value)) {
                callback()
            } else {
                callback(new Error('请输入正确的手机号码'))
            }
        }
        // 验证确认密码
        let checkRePass = (rule, value, callback) => {
            if (value === '') {
                callback(new Error('请再次输入密码'));
            }else if (value !== this.register.password) {
                callback(new Error('两次输入密码不一致'));
            } else {
                callback();
            }
        };
        // 验证中文姓名
        let checkRealName = (rule, value, callback) => {
            //验证名字的正则表达式
            const realnameReg = /^[\u4E00-\u9FA5]{2,6}$/
            if (!value) {
                return callback(new Error('请输入真实姓名'))
            }
            setTimeout(() => {
                if (!realnameReg.test(value)) {
                    return callback(new Error('请输入2-6个汉字'))
                } else {
                    callback()
                }
            }, 100)
        };
    
        // 验证中文姓名
        let checkIdNumber = (rule, value, callback) => {
            const idNumberReg = /^[1-9][0-9]{5}([1][9][0-9]{2}|[2][0][0|1][0-9])([0][1-9]|[1][0|1|2])([0][1-9]|[1|2][0-9]|[3][0|1])[0-9]{3}([0-9]|[X])$/
            if (!value) {
                return callback(new Error('请输入身份证号码'))
            }
            setTimeout(() => {
                if (!idNumberReg.test(value)) {
                    return callback(new Error('请输入正确格式的身份证号码'))
                } else {
                    callback()
                }
            }, 100)
        }
        return {
            loading: false,
            register:{
                username:'',
                mobile:'',
                mobilecode:'',
                email:'',
                password:'',
                repassword:'',
                realname:'',
                radios:'',
                idcard:'',
            },
            registerRules: {
                username: [
                    { required: true, message: '请输入用户名', trigger: 'blur' },
                    { min: 6, max: 18, message: "长度在 6 到 18个字符", trigger: "blur" },
                    ],
                mobile: [{ required: true, trigger: 'blur', validator: checkPhone  }],
                mobilecode: [{ required: true, message: '请输入手机验证', trigger: 'blur' }],
                email: [{ required: true, trigger: 'blur', validator: checkEmail }],
                password: [
                    { required: true, message: '请输入密码', trigger: 'blur' },
                    { min: 6, max: 18, message: "长度在 6 到 18个字符", trigger: "blur" },
                    ],
                repassword:[{ required: true, trigger: 'blur', validator: checkRePass }],
                realname: [{ required: true, trigger: 'blur', validator: checkRealName  }],
                idcard: [{ required: true, trigger: 'blur' , validator: checkIdNumber }],
                verify: [{ required: true, message: '请输入验证码', trigger: 'blur' }]
            },
            verifySrc:'',
            verify_status:true,
            success_url:'',
            site_title:'',
        }
    },
    
    mounted(){
        this.captch()
    },
    methods:{
        captch(){
            axios("{:url('/verify')}").then(res => {
                if(res.data.status == 200){
                    this.verifySrc = res.data.data.img
                    this.register.key = res.data.data.key
                    this.success_url = res.data.success_url
                    this.site_title = res.data.site_title
                }else{
                    this.$message.error('验证码获取失败!')
                }
            })
        },
        refeshVerifySrc() {
            this.captch()
        },
        handleRegister(){
            this.$refs['register'].validate(valid => {
                if(valid){
                    this.loading = true
                    axios.post("{:url('/register')}",this.register).then(res => {
                        if(res.data.status == 200){
                            this.$message.success(res.data.msg)
                            window.location.href = '/';
                        }else{
                            this.loading = false
                            this.refeshVerifySrc()
                            this.$message.error(res.data.msg)
                        }
                    })
                }
            })
        }
    },
})

 

你可能感兴趣的:(vue.js,javascript,前端)