React表单验证

本文介绍了在React.js中进行表单验证的方法,当表单失去焦点时能即时显示错误信息。为了防止用户在看到错误后仍尝试提交,实现了在点击注册按钮时弹出提示‘请完善用户信息’的弹框。文章主要展示了表单验证的1.0版本实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在写表单验证时,经过不断完善使得表单失去焦点时会提示错误信息。

为防止用户的恶搞,即提示错误信息时依然点击注册按钮,此时弹出弹框提示“请完善用户信息”。 

下面为表单验证1.0版本,2.0版本没有展示出来。 

//输入框文字判断
      validatorInput = (data) =>{
         // 使用方法判断是否为空
       let errors = {};

         if(data.username.length<2||data.username.length>8){
                 errors.username='用户名长度为2~8位'
         }
        if(data.username.length<2){
                     errors.username = '用户名长度小于2';
                }else if(data.username.length>8){
                     errors.username='用户名长度大于8'
         }
    
        if(!validator.isEmail(data.email)){
             errors.email = '邮箱格式不正确';
        }
    
        if(validator.isEmpty(data.password)){
             errors.password = '密码不能为空';
         }
    
        if(!validator.equals(data.password,data.passwordConfirmation)){
             errors.passwordConfirmation = '两次密码不相同';
         }
    
         return{ 
            
            isValid:!isEmpty(errors),
             errors
         }
           
        
    // }

//提交事件
   //提交事件
    onSubmit=(e)=>{
        
         e.preventDefault();
        // console.log(this.state.username)
        //  console.log(this.state.username.length)
       
        // var result = this.validatorInput(this.state)
        // this.setState({
        //     errors:result.errors
        // })
        // console.log(this.state)
        当点击注册事件,有一个input不符合要求时会弹出弹框
        if(this.state.errorsUsername||
            this.state.errorsEmail
            ||this.state.errorsPassword
            ||this.state.errorsPasswordConfirmation){
            alert('请完善用户信息')
        }
        
    }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值