vue 身份证18位验证

<el-row>
  <el-col :span="24">
     <el-form-item label="投诉人身份证号" prop="idCard">
        <el-input v-model="complaintForm.idCard" onkeyup="this.value=this.value.replace(/[^\X0-9]/g, '')" placeholder="请输入身份证号(数字0-9 X为大写)" style="width: 300px;" :disabled="isDetails"></el-input>
     </el-form-item>
  </el-col>
</el-row>

onkeyup="this.value=this.value.replace(/[^\X0-9]/g, '')"  这句话就是说只能输入汉字 输入别的会直接删除掉

封装一个js 在每个页面都可以调用; 引用部分就不介绍了 直接上js代码

   export function isIdentityId(identityId) {
  var patrn = /(^\d{15}$)|(^\d{17}(\d|X|x)$)/;//长度或格式校验
  //地区校验
  var 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 sBirthday = (
    identityId.substr(6, 4) +
    "-" +
    Number(identityId.substr(10, 2)) +
    "-" +
    Number(identityId.substr(12, 2))
  ).replace(/-/g, "/"),
    d = new Date(sBirthday)
  // 身份证号码校验 最后4位  包括最后一位的数字/字母X
  var sum = 0,
    weights = [7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2],
    codes = "10X98765432";
  for (var i = 0; i < identityId.length - 1; i++) {
    sum += identityId[i] * weights[i];
  }
  var last = codes[sum % 11]; //计算出来的最后一位身份证号码

  var errorMsg = '';
  if (identityId === '') {
    errorMsg = "身份证号不能为空"
  } else if (!patrn.exec(identityId)) {
    errorMsg = "你输入的身份证长度或格式错误"
  } else if (!aCity[parseInt(identityId.substr(0, 2))]) {
    errorMsg = "你的身份证地区非法"
  } else if (sBirthday != d.getFullYear() + "/" + (d.getMonth() + 1) + "/" + d.getDate()) { errorMsg = "身份证上的出生日期非法" } else if (identityId[identityId.length - 1] != last) {
    errorMsg = "你输入的身份证号非法"
  }
  return errorMsg;
}

在data里面引入

data() {
    var icdId  = (rule, value, callback) => {
      var errorMsg = isIdentityId(value);
      if (errorMsg != "") {
        callback(new Error(errorMsg));
      }     
    };
}

phoneNum: [
          { required: true, message: "请填写投诉人手机号", trigger: "blur" },
          { validator: isPhone, trigger: "blur" },

        ], 

 

希望对大家有所帮助  校验真实性最好的方法是接入*系统 

 


 

上一篇:继承方法-->一级一级继承


下一篇:探索两种优雅的表单验证——策略设计模式和ES6的Proxy代理模式