Element 表单验证绑定元素后发现rule不生效,required必填报错,input内填了值也报错

async-validator: ['username is required']

 出现这种情况,去核对el-form-item 绑定的prop 与input内绑定的属性值是否一致,不一致则会出现这个BUG

<el-form-item label="姓名:" prop="name">
                <el-input v-model="userInfo.username" style="width: 300px" />
 </el-form-item>
userInfo: {
        username: '',
        password2: ''
      },
      rules: {
        username: [{ required: true, message: '请输入姓名', trigger: 'blur' }],
        password2: [
          { required: true, message: '请输入密码', trigger: 'blur' },
          { min: 3, max: 8, message: '密码长度在3-8以内', trigger: 'blur' }
        ]
      }

确保 v-model双向绑定的数据 属性名与prop名字一致,也就是与rule 下的规则名一致

v-model=“userInfo.username”

el-form-item prop="username"

rules:{username:[xxxxx]}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
对于 Element UI 验证中文件上传的问题,您可以使用 `el-upload` 组件结合验证规则来实现。 首先,您需要在中使用 `el-upload` 组件,并设置项的验证规则: ```vue <template> <el-form :model="formData" :rules="formRules"> <el-form-item label="文件上传" prop="file" required> <el-upload v-model="formData.file" :action="uploadUrl" :file-list="fileList" list-type="text"> <el-button size="small" type="primary">点击上传</el-button> </el-upload> </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 { formData: { file: null, }, fileList: [], formRules: { file: [ { required: true, message: '请上传文件', trigger: 'change' }, ], }, }; }, methods: { submitForm() { this.$refs.form.validate((valid) => { if (valid) { // 验证通过,执行提交操作 console.log('提交'); } else { console.log('验证未通过'); return false; } }); }, }, }; </script> ``` 在上述代码中,我们使用了 `required` 属性来标记文件上传为项,并且在 `formRules` 中设置了相应的验证规则。当用户点击提交按钮时,会触发 `submitForm` 方法,在该方法中调用 `this.$refs.form.validate` 来进行验证。如果验证通过,则可执行提交操作;如果验证未通过,则提示用户。 请注意,上述代码只是一个示例,您需要根据自己的项目情况进行相应的调整和优化。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值