ElementUI的el-form组件的rules参数是用来定义表单验证规则的,它是一个对象,其中的每个属性对应表单中一个表单项的验证规则。
以下是一个简单的例子,展示如何为el-form组件设置验证规则:
<template>
  <el-form :model="form" :rules="rules" ref="form">
    <el-form-item label="用户名" prop="username">
      <el-input v-model="form.username"></el-input>
    </el-form-item>
    <el-form-item label="密码" prop="password">
      <el-input type="password" v-model="form.password"></el-input>
    </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 {
        form: {
          username: '',
          password: ''
        },
        rules: {
          username: [
            { required: true, message: '请输入用户名', trigger: 'blur' },
            { min: 3, max: 10, message: '用户名长度在 3 到 10 个字符', trigger: 'blur' }
          ],
          password: [
            { required: true, message: '请输入密码', trigger: 'blur' },
            { min: 6, max: 12, message: '密码长度在 6 到 12 个字符', trigger: 'blur' }
          ]
        }
      };
    },
    methods: {
      submitForm() {
        this.$refs.form.validate(valid => {
          if (valid) {
            alert('验证通过');
          } else {
            console.log('验证失败');
            return false;
          }
        });
      }
    }
  };
</script>在这个例子中,rules对象包含了username和password两个属性,分别代表表单中的用户名和密码字段。每个属性的值是一个数组,数组中包含了验证规则对象。每个规则对象包含required(是否必填)、message(验证不通过时的提示信息)和trigger(触发验证的时机,如blur是指在输入框失去焦点时验证)。
当用户尝试提交表单时,通过调用this.$refs.form.validate方法可以触发表单的验证,如果所有字段都符合规则,则可以继续进行后续的提交操作;如果有任何一个字段不符合规则,则不会继续执行提交操作,并显示对应的错误信息。