zoukankan      html  css  js  c++  java
  • 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

  • 相关阅读:
    mysql慢查询日志功能的使用
    回顾JavsScript对象的克隆
    JavaScript的几种继承方式
    再谈JavaScript中的闭包
    重温JavaScript预编译的四个步骤
    PHP常用设计模式
    编译 php-memcache 扩展时提示Cannot find autoconf
    CentOS 7 下编译安装lnmp之PHP篇详解
    CentOS 7 下编译安装lnmp之MySQL篇详解
    MySQL的转义符 ` 作用
  • 原文地址:https://www.cnblogs.com/qinshizhen/p/15597044.html
Copyright © 2011-2022 走看看