element-ui表单验证失效问题

问题描述:

element-ui中的表单项校验时,表单el-form和每个表单项el-form-item分别设置了rules和prop,且输入时遵循校验规则,但校验仍不通过

<el-form :model="ruleForm" :rules="rules" ref="ruleForm" label-width="100px" class="demo-ruleForm">
  <el-form-item label="活动名称" prop="name">
    <el-input v-model="ruleForm.name"></el-input>
  </el-form-item>
  <el-form-item label="活动形式" prop="desc">
    <el-input type="textarea" v-model="ruleForm.desc"></el-input>
  </el-form-item>
  <el-form-item>
    <el-button type="primary" @click="submitForm('ruleForm')">立即创建</el-button>
    <el-button @click="resetForm('ruleForm')">重置</el-button>
  </el-form-item>
</el-form>
<script>
  export default {
    
    
    data() {
    
    
      return {
    
    
        ruleForm: {
    
    
          name: '',
          desc: ''
        },
        rules: {
    
    
          name: [
            {
    
     required: true, message: '请输入活动名称', trigger: 'blur' },
            {
    
     min: 3, max: 5, message: '长度在 3 到 5 个字符', trigger: 'blur' }
          ],
          desc: [
            {
    
     required: true, message: '请填写活动形式', trigger: 'blur' }
          ]
        }
      };
    },
    methods: {
    
    
      submitForm(formName) {
    
    
        this.$refs[formName].validate((valid) => {
    
    
          if (valid) {
    
    
            alert('submit!');
          } else {
    
    
            console.log('error submit!!');
            return false;
          }
        });
      },
      resetForm(formName) {
    
    
        this.$refs[formName].resetFields();
      }
    }
  }
</script>

原因分析:

官方文档说el-form-item的prop可选值应为form组件的model中的字段,所以如果prop与内部的el-input绑定的model字段不一致就会出现校验失效。

表单项可选值

解决方案:

统一prop绑定的字段和el-form-item内部表单项绑定的字段

Guess you like

Origin blog.csdn.net/weixin_42043252/article/details/119870226