element-ui表单验证,常用的验证规则示例

前端 2019-11-19T12:03:10 浏览:160

element-ui表单验证,常用的验证规则示例,自定义验证规则,前端界面经常会接收到用户输入,如果不加验证,所有的输入直接提交到后端,如果成功,可能会携带不合法的数据,如果失败造成服务器压力,以下是element-ui发送前的数据校验。

需求:

必填:
1.学号:学号必须由10位数字构成
2.姓名:
3.专业:
4.手机:由11位数构成,并且以13、14、15、16、17、18、19 开头

可选:
5.邮箱:符合邮箱格式
6.简介:

<template>
  <div class="container">
    <div class="title">新增学生</div>
    <div class="wrap">
      <el-row>
        <el-form
          :model="form"
          status-icon
          ref="form"
          :rules="rules"
          label-width="100px"
          @submit.native.prevent>
          <el-form-item label="学号" prop="no">
            <el-input size="medium" v-model="form.no" placeholder="请填写学号"></el-input>
          </el-form-item>
          <el-form-item label="姓名" prop="name">
            <el-input size="medium" v-model="form.name" placeholder="请填写图片地址"></el-input>
          </el-form-item>
          <el-form-item label="专业" prop="major_name">
            <el-select v-model="form.major_name" placeholder="请选择专业">
              <el-option
                v-for="item in majorList"
                :key="item.value"
                :label="item.label"
                :value="item.value">
              </el-option>
            </el-select>
          </el-form-item>
          <el-form-item label="手机" prop="mobile">
            <el-input size="medium" v-model="form.mobile" maxlength="11" placeholder="请填写手机"></el-input>
          </el-form-item>
          <el-form-item label="邮箱" prop="email">
            <el-input size="medium" v-model="form.email"  placeholder="请填写邮箱"></el-input>
          </el-form-item>
          <el-form-item label="简介" prop="summary">
            <el-input
              size="medium"
              type="textarea"
              :autosize="{ minRows: 4, maxRows: 8}"
              placeholder="请输入简介"
              v-model="form.summary">
            </el-input>
          </el-form-item>
          <el-form-item class="submit">
            <el-button type="primary" @click="submitForm('form')">保 存</el-button>
            <el-button @click="resetForm('form')">重 置</el-button>
          </el-form-item>
        </el-form>
      </el-row>
    </div>

  </div>
</template>

<script>
export default {
  data() {
    const validNo = (rule, value, callback) => {
      const reg = /[0-9]{10}$/
      if (!reg.test(value)) {
        callback(new Error('学号必须是由10位数字'))
      } else {
        callback()
      }
    }
    const validMobile = (rule, value, callback) => {
      const reg = /^1[3456789]\d{9}$/
      if (!reg.test(value)) {
        callback(new Error('请输入正确的手机号11位'))
      } else {
        callback()
      }
    }
    return {
      // 测试数据
      majorList: [{
        value: '电子与通信工程',
        label: '电子与通信工程',
      }, {
        value: '应用电子技术',
        label: '应用电子技术',
      }, {
        value: '电子科学与技术',
        label: '电子科学与技术',
      }, {
        value: '通信工程',
        label: '通信工程',
      }, {
        value: '电子信息工程',
        label: '电子信息工程',
      }],
      form: {
        no: '',
        name: '',
        major_name: '',
        mobile: '',
        email: '',
      },
      // 验证规则
      rules: {
        no: [
          {
            message: '请输入正确的学号',
            trigger: 'blur',
            required: true,
          },
          {
            validator: validNo,
            trigger: 'blur',
          },
        ],
        name: [
          {
            message: '姓名不能为空',
            trigger: ['blur', 'change'],
            required: true,
          },
        ],
        major_name: [
          {
            message: '专业不能为空',
            trigger: ['blur', 'change'],
            required: true,
          },
        ],
        mobile: [
          {
            message: '请输入正确的手机号',
            trigger: 'blur',
            required: true,
          },
          {
            validator: validMobile,
            trigger: 'blur',
          },
        ],
        email: [
          {
            type: 'email', // type:
            message: '请输入正确的邮箱地址或者不填',
            trigger: ['blur', 'change'],
          },
        ],
      },
    }
  },
  methods: {
    async submitForm(formName) {
      console.log(this.$refs)
      this.$refs[formName].validate(async (valid) => {
        if (valid) {
          console.log('数据提交的后端程序')
        } else {
          console.log('error submit!!')
          this.$message.error('请填写正确的信息')
        }
      })
    },
    // 重置表单
    resetForm(formName) {
      this.$refs[formName].resetFields()
    },
  },
}
</script>