^([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 函数进行身份证号码校验。如果身份证号码符合要求,则提交表单;否则,显示一个错误提示。

好文链接

评论可见,请评论后查看内容,谢谢!!!
 您阅读本篇文章共花了: