天天看點

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字段不一緻就會出現校驗失效。

element-ui表單驗證失效問題問題描述:原因分析:解決方案:

解決方案:

統一prop綁定的字段和el-form-item内部表單項綁定的字段