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

1.form表单写法

javascript 复制代码
<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的校验写法

javascript 复制代码
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
    }
  }
相关推荐
朦胧之15 小时前
AI 编程-老项目改造篇
java·前端·后端
swipe18 小时前
从 0 到 1 实现大文件上传:分片、秒传、断点续传、暂停、重试与服务端合并
前端·javascript·面试
爱勇宝18 小时前
我做了一个只用来搜歌词的小 App
android·前端·后端
甲维斯18 小时前
用AI还原《坦克大战》并3D化升级!
前端·人工智能·游戏开发
IT_陈寒19 小时前
SpringBoot自动配置坑了我一晚上,原来问题出在这
前端·人工智能·后端
kyriewen19 小时前
AI 生成的代码能跑就行?这 5 个坑迟早炸
前端·javascript·ai编程
谷子在生长20 小时前
纯血鸿蒙自定义弹窗最佳实践:从「到处复制」到「一行调用」
前端·harmonyos
壹方秘境20 小时前
我用Go语言开发了一个跨平台的HTTPS抓包和调试工具
前端·后端·ios
神秘面具男20 小时前
HarmonyOS 6.0跨端远程控制
前端·后端
枫树下x20 小时前
NestJS基础框架
前端