js怎么判断是否为手机号?js格式校验方法

数据格式正确与否是表单填写不可避免的一个流程,现整理一些较为常用的信息格式校验方法。

判断是否为手机号码

js 复制代码
// 判断是否为手机号码
function isPhoneNumber(phone) {
  return /^[1]\d{10}$/.test(phone)
}

判断是否为移动手机号

js 复制代码
function isChinaMobilePhone(phone) {
  var reg = new RegExp(/^(13[456789]|147|15[012789]|178|18[23478]|198)[0-9]{8}$/)
  return reg.test(phone)
}

判断是否为座机

js 复制代码
function isTelephone(phone) {
  return /^[0][0-9]{2,3}[-]?[0-9]{6,9}$/.test(phone)
}

身份证校验

js 复制代码
// 身份证校验 简单校验
function checkIDCardSimple(code) {
  return /^([0-9a-zA-Z]{15}|[0-9a-zA-Z]{18})$/.test(code)
}

// 身份证校验 加强校验
function checkIDCard(code) {
  // 校验非空
  if (!code) {
    return false
  }
  // 校验长度
  if (code.length != 15 && code.length != 18) {
    return false
  }
  // 定义判别用户身份证号的正则表达式(15位或者18位,最后一位可以为字母)
  //假设18位身份证号码:41000119910101123X  410001 19910101 123X
  //^开头
  //[1-9] 第一位1-9中的一个      4
  //\\d{5} 五位数字           10001(前六位省市县地区)
  //(18|19|20)                19(现阶段可能取值范围18xx-20xx年)
  //\\d{2}                    91(年份)
  //((0[1-9])|(10|11|12))     01(月份)
  //(([0-2][1-9])|10|20|30|31)01(日期)
  //\\d{3} 三位数字            123(第十七位奇数代表男,偶数代表女)
  //[0-9Xx] 0123456789Xx其中的一个 X(第十八位为校验值)
  //$结尾

  //假设15位身份证号码:410001910101123  410001 910101 123
  //^开头
  //[1-9] 第一位1-9中的一个      4
  //\\d{5} 五位数字           10001(前六位省市县地区)
  //\\d{2}                    91(年份)
  //((0[1-9])|(10|11|12))     01(月份)
  //(([0-2][1-9])|10|20|30|31)01(日期)
  //\\d{3} 三位数字            123(第十五位奇数代表男,偶数代表女),15位身份证不含X
  //$结尾
  
  var reg = new RegExp(/(^[1-9]\d{5}(18|19|20)\d{2}((0[1-9])|(10|11|12))(([0-2][1-9])|10|20|30|31)\d{3}[0-9Xx]$)|(^[1-9]\d{5}\d{2}((0[1-9])|(10|11|12))(([0-2][1-9])|10|20|30|31)\d{3}$)/)
  var matches = reg.test(code)
  if (matches) {
    // 15位的身份证,直接返回合法
    if (code.length == 15) {
      return true
    }
    // 18位的进一步校验
    try {
      // TODO:
    } catch(e) {
      console.error(e)
      return false
    }
    
  }
  return matches
}

身份证校验15位

js 复制代码
function checkIDCard15(code) {
  return /^([0-9a-zA-Z]{15})$/.test(code)
}

身份证校验18位

js 复制代码
function checkIDCard18() {
  return /^([0-9a-zA-Z]{18})$/.test(code)
}

户口簿校验

js 复制代码
// 户口簿校验 9位数字
function checkHuKouBook(code) {
  return /^\d{9}$/.test(code)
}

护照校验

js 复制代码
// 护照校验
function checkPassport(code) {
  return /^((1[45]\d{7})|(G\d{8})|(P\d{7})|(S\d{7,8}))?$/.test(code)
}

军官证校验

js 复制代码
// 军官证校验
// 规则:军/兵/士/文/职/广/(其他中文) + "字第" + 4到8位字母或数字 + "号"
// 示例:军字第2002488号, 士字第P011816X号
function checkOfficerCard(code) {
  return /^[\u4E00-\u9FA5](字第)([0-9a-zA-Z]{4,8})(号?)$/.test(code)
}

驾驶证校验

js 复制代码
// 驾驶证校验 12位数字
function checkDriveCard(code) {
  return /^\d{12}$/.test(code)
}

台湾居民来往大陆通行证

js 复制代码
// 台湾省居民来往大陆通行证
// 规则:新版8位或18位数字,旧版10位数字 + 英文字母
// 示例:12345678 或 1234567890B
function checkTwCard(code) {
  return /^\d{8}|^[a-zA-Z0-9]{10}|^\d{18}$/.test(code)
}

港澳居民来往内地通行证

js 复制代码
// 港澳居民来往内地通行证
// 规则:H/M + 10位或6位数字
// 示例:H1234567890
function checkHMCard(code) {
  return /^[HMhm]{1}([0-9]{10}|[0-9]{8})$/.test(code)
}
相关推荐
lecepin1 小时前
AI Coding 资讯 2025-09-17
前端·javascript·面试
IT_陈寒1 小时前
React 18实战:7个被低估的Hooks技巧让你的开发效率提升50%
前端·人工智能·后端
树上有只程序猿2 小时前
终于有人把数据库讲明白了
前端
猩兵哥哥2 小时前
前端面向对象设计原则运用 - 策略模式
前端·javascript·vue.js
司宸2 小时前
Prompt设计实战指南:三大模板与进阶技巧
前端
RoyLin2 小时前
TypeScript设计模式:抽象工厂模式
前端·后端·typescript
华仔啊2 小时前
Vue3+CSS 实现的 3D 卡片动画,让你的网页瞬间高大上
前端·css
江城开朗的豌豆2 小时前
解密React虚拟DOM:我的高效渲染秘诀 🚀
前端·javascript·react.js
vivo互联网技术2 小时前
拥抱新一代 Web 3D 引擎,Three.js 项目快速升级 Galacean 指南
前端·three.js