随笔 - 47,  文章 - 1,  评论 - 2,  阅读 - 51381

遇到的问题:

重新在输入框输入的数据,不能被检测。错误效果图如下:

      使用的代码是:

复制代码
<div class="login-form">
                <el-form ref="form" label-width="0px" :model="loginForm" :rules="loginRules">
                    <el-form-item prop="name">
                        <el-input prefix-icon="el-icon-user-solid" v-model="loginForm.username"></el-input>
                    </el-form-item>
                    <el-form-item prop="pwd">
                        <el-input prefix-icon="el-icon-unlock" v-model="loginForm.password" type="password"></el-input>
                    </el-form-item>
                    <div class="login-btn">
                        <el-button type="primary">登陆</el-button>
                        <el-button type="primary">注册</el-button>
                        
                    </div>

                </el-form>
            </div>

data(){
       return {
           loginForm:{
               username:"小白",
               password:"123",
           },
           loginRules:{
               name:[
                   {required:true,message:"请输入用户名",trigger:"blur"},
                    { min: 2, max: 5, message: '长度在 3 到 5 个字符', trigger: 'blur' }
               ],
               pwd:[
                   {required: true, message:'请输入', trigger: 'blur'}
                ]
           }
       }
   }
复制代码

预期的结果是:每次输入数据,在输入框失去焦点之后,数据就会被检测。

问题所在:rules中的对象(本例中是loginRules)的属性名必须和数据双向绑定v-model中的命名要一致

所以需要把loginForm中的name改成username,把pwd改成password。

以下为修改后的部分代码:

复制代码
loginRules:{
               username:[
                   {required:true,message:"请输入用户名",trigger:"blur"},
                    { min: 2, max: 5, message: '长度在 3 到 5 个字符', trigger:'blur' }
               ],
               password:[
                //    {required: true, message:'请输入', trigger: 'blur'}
                   {required: true, min: 3, max: 5, message: '长度在 3 到 5 个字符', trigger:'blur' }
                ]
           }
复制代码

  让属性的命名保持一致后,表单数据就可以成功验证啦。

可喜可贺,哈哈~

posted on   bro阿柒  阅读(710)  评论(1编辑  收藏  举报
编辑推荐:
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
阅读排行:
· 使用C#创建一个MCP客户端
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· ollama系列1:轻松3步本地部署deepseek,普通电脑可用
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 按钮权限的设计及实现
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

点击右上角即可分享
微信分享提示