TS+elementUI的表格做form校验写法(手机/邮箱号验证)

1.form表单写法 

<template>
  <div style="height:100%;width:100%;position:relative">

    <el-dialog title="编辑" :visible.sync="dialogVisible" width='15%' :close-on-click-modal='false'>
      <el-form :model="form" :rules="rules" ref="ruleForm">
        <el-form-item label="账号" :label-width="formLabelWidth" prop="userCode" v-show="addOrEdit">
          <el-input :readonly="true" v-model="form.userCode" autocomplete="off"></el-input>
        </el-form-item>
        <!-- <el-form-item label="密码" :label-width="formLabelWidth" prop="userPwd" v-show="addOrEdit">
          <el-input v-model="form.userPwd" autocomplete="off"></el-input>
        </el-form-item> -->
        <el-form-item label="姓名" :label-width="formLabelWidth" prop="userName">
          <el-input v-model="form.userName" autocomplete="off"></el-input>
        </el-form-item>
        <el-form-item label="手机号" :label-width="formLabelWidth" prop="phoneNumber">
          <el-input v-model="form.phoneNumber" autocomplete="off"></el-input>
        </el-form-item>
        <el-form-item label="微信号" :label-width="formLabelWidth" prop="wechatCode">
          <el-input v-model="form.wechatCode" autocomplete="off"></el-input>
        </el-form-item>
        <el-form-item label="邮箱" :label-width="formLabelWidth" prop="email">
          <el-input v-model="form.email" autocomplete="off"></el-input>
        </el-form-item>

      </el-form>
      <div slot="footer" class="dialog-footer">
        <el-button @click="append">取 消</el-button>
        <el-button type="primary" @click="addOk('ruleForm') ">确 定</el-button>
      </div>
    </el-dialog>
  </div>
</template>

2.rules的校验写法

private rules: any = {
    userCode: [{ required: true, message: '请填写账号', trigger: 'blur' }],
    userName: [{ required: true, message: '请填写姓名', trigger: 'blur' }],
    phoneNumber: [
      { required: true, message: '请填写手机号', trigger: 'blur' },
      { validator: this.validatePhone, message: '请填写11位手机号', trigger: 'blur' }
    ],
    email: [
      { required: true, message: '请填写邮箱号', trigger: 'blur' },
      { validator: this.validateEmail, message: '请填写正确的邮箱号', trigger: 'blur' }
    ],
    wechatCode: [{ required: true, message: '请填写微信号', trigger: 'blur' }]
    // userPwd: [{ required: true, message: '请填写登录密码', trigger: 'blur' }]
    
  }
private validatePhone() {
    if (!/^1(3|4|5|6|7|8)\d{9}$/.test(this.form.phoneNumber)) {
      return false
    } else {
      return true
    }
  }
  private validateEmail() {
    if (!/^[a-zA-Z0-9_.-]+@[a-zA-Z0-9-]+(\.[a-zA-Z0-9-]+)*\.[a-zA-Z0-9]{2,6}$/.test(this.form.email)) {
      return false
    } else {
      return true
    }
  }

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-05-25 19:58:43       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-05-25 19:58:43       100 阅读
  3. 在Django里面运行非项目文件

    2024-05-25 19:58:43       82 阅读
  4. Python语言-面向对象

    2024-05-25 19:58:43       91 阅读

热门阅读

  1. 测试驱动开发(TDD)的探析

    2024-05-25 19:58:43       30 阅读
  2. vue的图片上传

    2024-05-25 19:58:43       29 阅读
  3. 【设计模式】单例模式的任务队列

    2024-05-25 19:58:43       29 阅读
  4. Python学习---基于TCP的模拟浏览器请求响应案例

    2024-05-25 19:58:43       28 阅读
  5. 【Python】单例模式和工厂模式

    2024-05-25 19:58:43       34 阅读
  6. 如何选择适合自己需求的扬州独立服务器方案?

    2024-05-25 19:58:43       30 阅读
  7. 什么是分布式?为什么需要分布式?

    2024-05-25 19:58:43       31 阅读
  8. 07网络编程及网络基础知识

    2024-05-25 19:58:43       34 阅读
  9. 货币系统一(DP[i][j]二维)

    2024-05-25 19:58:43       27 阅读