• elementui form 相关表单验证


    **综合网上和自己平常做个小记录**

    <template>
      <div>
        <el-form :model="tableForm" ref="tableForm">
          <el-table
            :data="tableForm.tableData"
            border
            style=" 100%"
          >
            <el-table-column label="姓名">
              <template slot-scope="scope">
                <el-form-item :prop="`tableData.${scope.$index}.name`" :rules="tableRules.name">
                  <el-input v-model="scope.row.name"></el-input>
                </el-form-item>
              </template>
            </el-table-column>
            <el-table-column label="年龄">
              <template slot-scope="scope">
                <el-form-item :prop="`tableData.${scope.$index}.age`" :rules="tableRules.age">
                  <el-input v-model="scope.row.age"></el-input>
                </el-form-item>
              </template>
            </el-table-column>
            <el-table-column label="电话">
              <template slot-scope="scope">
                <el-form-item :prop="`tableData.${scope.$index}.phone`" :rules="tableRules.phone">
                  <el-input v-model="scope.row.phone"></el-input>
                </el-form-item>
              </template>
            </el-table-column>
          </el-table>
        </el-form>
        <div>
          <el-button type="primary" @click="submitForm('tableForm')">提交</el-button>
          <el-button @click="resetForm('tableForm')">重置</el-button>
        </div>
      </div>
    </template>
    
    <script>
    export default {
      data() {
        // 自定义校验规则
        var checkPhone = (rule, value, callback) => {
            let reg = /^((0\d{2,3}-\d{7,8})|(1[3584]\d{9}))$/
            if (!reg.test(value)) {
              callback(new Error('请输入正确号码'))
            } else {
              callback()
            }
        }
        return {
          tableForm: {
            tableData: [
              {
                name: "",
                age: "",
                phone: ""
              }
            ]
          },
          tableRules: {
            // 姓名
            name: [
              { required: true, message: "请输入姓名" , trigger: 'blur' },
              { max: 20, message: "长度在20个字符以内" , trigger: 'blur' }
            ],
            //年龄
            age: [
              { required: true, message: "请输入年龄", trigger: 'blur' },
              { max: 20, message: "长度在20个字符以内", trigger: 'blur' }
            ],
            //电话
            phone: [
              { required: true, message: "请输入电话", trigger: 'blur' },
              { validator: checkPhone, 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();
        },
      // 触发自定义校验
      // this.$refs[formName].validateField('imgUrl')
      },
    };
    
    </script>

     实例外链:https://www.cnblogs.com/lhl66/p/12848559.html

  • 相关阅读:
    Form 中调用指定请求并给定默认参数
    OAF 汇总行的做法
    EBS 开发常用SQL
    EBS 中常用的配置文件及说明
    OAF 常见概念介绍
    OAF 多语言的实现
    OAF 个性化基础
    OAF 开发前置配置
    条款20 STL函数对象
    条款19 command 模式与好莱坞法则
  • 原文地址:https://www.cnblogs.com/qinshizhen/p/15597044.html
Copyright © 2020-2023  润新知