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
    }
  }
相关推荐
Codigger官方6 分钟前
Linux 基金会牵头成立 React 基金会:前端开源生态迎来里程碑式变革
linux·前端·react.js
90后的晨仔7 分钟前
🌟 Vue3 + Element Plus 表格开发实战:从数据映射到 UI 优化的五大技巧
前端
ObjectX前端实验室1 小时前
【图形编辑器架构】🧠 Figma 风格智能选择工具实现原理【猜测】
前端·react.js
天桥下的卖艺者1 小时前
R语言基于shiny开发随机森林预测模型交互式 Web 应用程序(应用程序)
前端·随机森林·r语言·shiny
技术钱1 小时前
vue3 两份json数据对比不同的页面给于颜色标识
前端·vue.js·json
路很长OoO1 小时前
Flutter 插件开发实战:桥接原生 SDK
前端·flutter·harmonyos
Flash Dog1 小时前
【Vue】——路由
vue.js
开水好喝2 小时前
Code Coverage Part I
前端
DoraBigHead2 小时前
🧭 React 理念:让时间屈服于 UI —— 从同步到可中断的演化之路
前端·javascript·面试
羊羊小栈2 小时前
基于「多模态大模型 + BGE向量检索增强RAG」的航空维修智能问答系统(vue+flask+AI算法)
vue.js·人工智能·python·语言模型·flask·毕业设计