首先是js函数中的代码:- /* 鼠标在身份证号文本框中时 */
- function cardIDFocus() {
- var nickName = document.getElementById("cardID");
- var nickNameId = document.getElementById("cardID_prompt");
- nickName.className = "input input_Focus";
- nickNameId.innerHTML = "请填写18位的身份证号";
- nickNameId.className = "prompt";
- }
- /* 鼠标离开身份证号文本框中时 */
- function cardIDBlur() {
- var idCard = document.jbxxForm.cardID.value;
- var regIdCard = /^(^[1-9]\d{7}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{3}$)|(^[1-9]\d{5}[1-9]\d{3}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])((\d{4})|\d{3}[Xx])$)$/;
- var nickName = document.getElementById("cardID");
- var nickNameId = document.getElementById("cardID_prompt");
- nickNameId.innerHTML = "";
- if (nickName.value == "") {
- nickNameId.innerHTML = "身份证号为必填项,请填写您的身份证号";
- nickNameId.className = "prompt_error";
- nickName.className = "input input_Blur";
- return false;
- } else if (regIdCard.test(idCard)) {
- if (idCard.length == 18) {
- var idCardWi = new Array(7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10,
- 5, 8, 4, 2); // 将前17位加权因子保存在数组里
- var idCardY = new Array(1, 0, 10, 9, 8, 7, 6, 5, 4, 3, 2); // 这是除以11后,可能产生的11位余数、验证码,也保存成数组
- var idCardWiSum = 0; // 用来保存前17位各自乖以加权因子后的总和
- for ( var i = 0; i < 17; i++) {
- idCardWiSum += idCard.substring(i, i + 1) * idCardWi[i];
- }
- var idCardMod = idCardWiSum % 11;// 计算出校验码所在数组的位置
- var idCardLast = idCard.substring(17);// 得到最后一位身份证号码
- // 如果等于2,则说明校验码是10,身份证号码最后一位应该是X
- if (idCardMod == 2) {
- if (!(idCardLast == "X" || idCardLast == "x")) {
- nickNameId.innerHTML = "身份证号码无效";
- nickNameId.className = "prompt_error";
- nickName.className = "input input_Blur";
- return false;
- }
- } else {
- // 用计算出的验证码与最后一位身份证号码匹配,如果一致,说明通过,否则是无效的身份证号码
- if (!(idCardLast == idCardY[idCardMod])) {
- nickNameId.innerHTML = "您填写的不是正确的身份证号";
- nickNameId.className = "prompt_error";
- nickName.className = "input input_Blur";
- return false;
- }
- }
- } else {
- nickNameId.innerHTML = "身份证号必须为18位";
- nickNameId.className = "prompt_error";
- nickName.className = "input input_Blur";
- return false;
- }
- } else {
- nickNameId.innerHTML = "必须填写您真实的身份证号";
- nickNameId.className = "prompt_error";
- nickName.className = "input input_Blur";
- return false;
- }
- nickNameId.className = "prompt_ok";
- nickName.className = "input";
- return true;
- }
复制代码 为了在显示提示时,提示客户,可用CSS动态改变文本框的效果:- /*注册页面提示样式*/
- .input_Blur {
- background-color: #fef4d0;
- border: solid 1px #999;
- margin: 0px 0px 8px 0px;
- height: 25px;
- }
- .input_Focus {
- background-color: #f1ffde;
- border: solid 1px #999;
- margin: 0px 0px 8px 0px;
- height: 25px;
- }
- .reg_input {
- height: 25px;
- }
- .prompt {
- font-size: 15px;
- color: #999;
- }
- .prompt_error {
- font-size: 15px;
- color: #C8180B;
- border: solid 1px #999;
- background-color: #fef4d0;
- padding: 0px 5px 0px 5px;
- height: 20px;
- }
- .prompt_ok {
- background-image: url(../image/register_write_ok.gif);
- background-repeat: no-repeat;
- width: 15px;
- height: 20px;
- margin: 5px 0px 0px 5px;
- }
复制代码 上面使用的图片可自行选择,并根据自己项目中的路径更改路径
|
|