前端表单中的手机号的验证

在我们前端开发,会对手机号的表单验证,不同的产品有不同的使用场景,下面写一下我在开发中进行的表单验证吧。

要验证的点:

手机号码的格式要正确。

向后端发送请求验证手机号是否存在

去空格(我看antd里的input没有什么属性可以去空格,就只能再写一个函数了)

来看看

javascript 复制代码
<template>
  <a-form
        ref="addUserModal"
        :model="createParams"
        :layout="'vertical'"
        style="padding: 20px"
        :rules="rules"
      >
   ...
   <a-form-item label="手机号码" name="phone">
          <a-input
            placeholder="请输入手机号码"
            v-model:value="createParams.phone"
            @blur="handleChange"
          />
    </a-form-item>
   </a-form>
</template>
javascript 复制代码
<script>

const rules = {
  password: [{ required: true, message: '请输入用户密码' }],
  phone: [
    { required: true, message: '请输入手机号', trigger: 'blur' },
    { validator: checkPhoneExist, trigger: 'blur' },
  ],
  .....
};
// 手机号码的正则表达式
const isPhoneValid = (phone: string) => {
  const phoneRegex = /^1[3-9]\d{9}$/;
  return phoneRegex.test(phone);
};

// 手机号重复监测
const checkPhoneExist = async (rule: Rule, value: string) => {
  const phoneCheck = {
    tableName: 'sys_user',
    fieldName: 'phone',
    fieldVal: value,
  };
  if (!isPhoneValid(value) && value !== undefined) {
    throw new Error('手机号格式不正确');
  }
  if (value) {
    try {
      const res = await checkRepeat(phoneCheck);
      if (res.code !== 200) {
        throw new Error('手机号已存在');
      }
    } catch (error) {
      throw new Error('手机号已存在');
    }
  }
};
// 去除空格
const handleChange = (e: any) => {
  createParams.value['phone'] = e.target.value.trim();
};
</script>

如果你有什么更好的实现方法,可以交流怕哦。

本人是一个入行一年,还没有师傅带的小白,好多东西都是在实际开发中遇到了在学习,解决,如果有什么不足的话,欢迎各位大佬可以与我交流哦,或者你有什么更好的实现方法,有可以告诉我哦!让 我学习,进步一下

相关推荐
英俊潇洒美少年2 分钟前
Vue3 响应式 + 编译优化 + Diff 三者如何配合工作
前端
英俊潇洒美少年3 分钟前
Vue3 完整渲染流程(从 createApp → mount → update → unmount)
前端·javascript·vue.js
前端Hardy8 分钟前
Pinia 比 Vuex 好用 10 倍?Vue3 状态管理终于不折磨人了!(新手复制即用)
前端·javascript·vue.js
前端Hardy16 分钟前
Vue3 的 v-model 双向绑定,90% 的人都用错了?(附 2026 最新避坑指南)
前端·javascript·vue.js
前端Hardy16 分钟前
救命!Vue3 的 Composition API,居然能让我少写 80% 冗余代码?(新手也能直接抄)
前端·javascript·vue.js
李剑一18 分钟前
前端必懂!一文搞懂 WebAssembly:Web/Electron/RN 全通用,你天天用的软件,底层都靠它
前端·webassembly
Definition30 分钟前
Claude Code 能养宠物了,体验下抽卡的感觉
前端·程序员
Daiyaosei35 分钟前
紧急安全警报:Axios npm 包被投毒事件详解与防护指南
前端·javascript·安全
We་ct40 分钟前
LeetCode 295. 数据流的中位数:双堆解法实战解析
开发语言·前端·数据结构·算法·leetcode·typescript·数据流
青槿吖43 分钟前
第一篇:Redis集群从入门到踩坑:3主3从保姆级搭建+核心原理一次性讲透|面试必看
前端·redis·后端·面试·职场和发展·bootstrap·html