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" }, ],
希望对大家有所帮助 校验真实性最好的方法是接入公安系统