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
    }
  }
相关推荐
杨进军5 分钟前
React 创建根节点 createRoot
前端·react.js·前端框架
ModyQyW20 分钟前
用 AI 驱动 wot-design-uni 开发小程序
前端·uni-app
说码解字27 分钟前
Kotlin lazy 委托的底层实现原理
前端
Q_970956391 小时前
java+vue+SpringBoo校园失物招领网站(程序+数据库+报告+部署教程+答辩指导)
java·数据库·vue.js
爱分享的程序员1 小时前
前端面试专栏-算法篇:18. 查找算法(二分查找、哈希查找)
前端·javascript·node.js
翻滚吧键盘1 小时前
vue 条件渲染(v-if v-else-if v-else v-show)
前端·javascript·vue.js
vim怎么退出1 小时前
万字长文带你了解微前端架构
前端·微服务·前端框架
你这个年龄怎么睡得着的1 小时前
为什么 JavaScript 中 'str' 不是对象,却能调用方法?
前端·javascript·面试
Java水解1 小时前
前端常用单位em/px/rem/vh/vm到底有什么区别?
前端
CAD老兵1 小时前
Vite 如何借助 esbuild 实现极速 Dev Server 体验,并支持无 source map 的源码调试
前端