在vue中使用js公共文件内的方法判断身份证号是否合规

首先我们要知道身份证号是由18位数组组成;

  1. 1-6位为省市区;
  2. 第1-2位数字表示:所在省份的代码;
    北京市:11
    天津市:12
    河北省:13
    山西省:14
    内蒙古自治区:15
    辽宁省:21
    吉林省:22
    黑龙江省:23
    上海市:31
    江苏省:32
    浙江省:33
    安徽省:34
    福建省:35
    江西省:36
    山东省:37
    河南省:41
    湖北省:42
    湖南省:43
    广东省:44
    广西壮族自治区:45
    海南省:46
    重庆市:50
    四川省:51
    贵州省:52
    云南省:53
    西藏自治区:54
    陕西省:61
    甘肃省:62
    青海省:63
    宁夏回族自治区:64
    新疆维吾尔自治区:65
  3. 第3-4位数字表示:所在城市的代码;
  4. 第5-6位数字表示:所在区县的代码;
  5. 7-14位为出生年、月、日;
  6. 15-17位都是同一地址辖区内的,以及同年同月同日出生人的顺序码;
  7. 第17位兼具性别标识功能,男单女双;
  8. 第18位数字是校检码:可以是0-9的数字,有时也用X表示;

开始编写代码

新建js文件用来存放公共方法,例如publicMethod文件夹内创建index.js;
在main.js中引入

import WAY from './publicMethod/index.js'
Vue.prototype.WAY = WAY

在index.js中添加

export default  {

}

在export default {}内添加方法;

checkIdCard:function(sId){
      const aCity = { 11: "北京", 12: "天津", 13: "河北", 14: "山西", 15: "内蒙古", 21: "辽宁", 22: "吉林", 23: "黑龙江", 31: "上海", 32: "江苏", 33: "浙江", 34: "安徽", 35: "福建", 36: "江西", 37: "山东", 41: "河南", 42: "湖北", 43: "湖南", 44: "广东", 45: "广西", 46: "海南", 50: "重庆", 51: "四川", 52: "贵州", 53: "云南", 54: "西藏", 61: "陕西", 62: "甘肃", 63: "青海", 64: "宁夏", 65: "新疆", 71: "台湾", 81: "香港", 82: "澳门", 91: "国外" };
      var iSum = 0;
      if (!/^\d{17}(\d|X|x)$/i.test(sId)) return false;
      sId = sId.replace(/x$/i, "a");
      if (aCity[parseInt(sId.substr(0, 2))] == null) return false;
      var sBirthday = sId.substr(6, 4) + "-" + Number(sId.substr(10, 2)) + "-" + Number(sId.substr(12, 2));
      var d = new Date(sBirthday.replace(/-/g, "/"));
      if (sBirthday != (d.getFullYear() + "-" + (d.getMonth() + 1) + "-" + d.getDate())) return false;
      for (var i = 17; i >= 0; i--) iSum += (Math.pow(2, i) % 11) * parseInt(sId.charAt(17 - i), 11);
      if (iSum % 11 != 1) return false;
      //aCity[parseInt(sId.substr(0,2))]+","+sBirthday+","+(sId.substr(16,1)%2?"男":"女");//此次还可以判断出输入的身份证号的人性别
      return true;
    },

在组件中使用进行if判断

if(this.WAY.checkIdCard(要传的值)){
    alert('合规')
  }else{
  	alert('不合规')
  }
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值