^([1-9]\d{5})(\d{4})(\d{2})(\d{2})(\d{3})(\d|X)$
这个正则表达式用于匹配中国身份证号码(18位),其中:
^
表示匹配字符串的开头[1-9]
表示匹配数字 1-9 中的任意一个\d{5}
表示匹配任意 5 个数字,即区域码(\d{4})(\d{2})(\d{2})
表示匹配出生年月日,其中\d{4}
表示匹配任意 4 个数字,\d{2}
表示匹配任意 2 个数字(\d{3})(\d|X)
表示匹配最后四位,其中\d{3}
表示匹配任意 3 个数字,\d|X
表示匹配最后一位数字或字母 X$
表示匹配字符串的结尾
所以,这个正则表达式可以匹配类似于 “110101198001011234” 的身份证号码。
需要注意的是,这个正则表达式并不能完全保证身份证
这个表达式怎么用到JS上面对字符串判断呢
在 JavaScript 中,可以使用 test
方法来测试一个字符串是否匹配一个正则表达式。 test
方法会返回一个布尔值,如果匹配成功则返回 true
,否则返回 false
。
你可以将上面的正则表达式编译成一个 RegExp 对象,然后调用它的 test
方法来判断字符串是否符合要求。例如:
const password = "110101198001011234";
const regex = /^([1-9]\d{5})(\d{4})(\d{2})(\d{2})(\d{3})(\d|X)$/;
const isValid = regex.test(password);
if (isValid) {
console.log("符合要求");
} else {
console.log("不符合要求");
}
在上面的示例代码中,首先定义了一个待校验的身份证号码 password
,然后将正则表达式编译成一个 RegExp
对象。
接下来调用 RegExp
对象的 test
方法,判断密码是否符合正则表达式的要求。最后输出校验结果。
如果你需要在表单中校验身份证号码时,可以在表单提交时触发一个函数进行校验。例如:
const form = document.querySelector("form");
const passwordInput = form.querySelector("#password");
form.addEventListener("submit", onSubmit);
function onSubmit(event) {
event.preventDefault();
const password = passwordInput.value;
const regex = /^([1-9]\d{5})(\d{4})(\d{2})(\d{2})(\d{3})(\d|X)$/;
const isValid = regex.test(password);
if (isValid) {
// 提交表单
form.submit();
} else {
// 显示错误提示
const error = document.querySelector("#error");
error.textContent = "不符合要求";
}
}
在上面的示例代码中,定义了一个表单元素和一个身份证号码输入框。当用户提交表单时,调用 onSubmit
函数进行身份证号码校验。如果身份证号码符合要求,则提交表单;否则,显示一个错误提示。