js验证出生日期

这次做毕业设计遇到一个小小的问题,就是在添加员工信息时要填写出生年月,当然常规的做法是用下拉列表来做,年月日用三个下拉列表来做:
<td height="40" align="right">出生年月:</td>
<td><select name="selectYear" id="selectYear" onChange="changeMonth()">

</select>

<select name="selectMonth" id="selectMonth" onChange="changeMonth()">

</select>

<select name="selectDay" id="selectDay">

</select>
日</td>


最开始的时候我想直接把给select添加option,比如月就直接添加12个option,日就直接添加31个option,不过后来发现不对劲,这样添加太麻烦啦,干嘛不用js来自动添加呢,其实这个也挺简单的嘛,o(︶︿︶)o 唉,看来还是没经验的表现啊,其实这样的东西应该第一感觉就是js嘛!赶紧做吧,其实这里用JS还可以让代码更健壮,不会出现BUG,因为如果像我开始那样做,会造成2月31这样不合常理的日期出现,而JS完全可以解决这些问题,废话少说代码贴出来啦!


var yearObj = null;
var monthObj = null;
var dayObj = null;

function showBirthDay() {
yearObj = document.tableForm.selectYear;
monthObj = document.tableForm.selectMonth;
dayObj = document.tableForm.selectDay;
//清空年份下拉列表的数据
yearObj.options.length = 0;
monthObj.options.length = 0;
dayObj.options.length = 0;
for(var i = 1900; i < 2012; i++) {
//$("<option value="+i+">"+i+"</option>").appendTo(yearObj);
var year = new Option(i,i);
yearObj.options.add(year);
}
for(var i = 1; i <= 12; i++) {
var month = new Option(i,i);
monthObj.options.add(month);
}
for(var i = 1; i <= 31; i++) {
var day = new Option(i,i);
dayObj.options.add(day);
}

}

//当月份改变时,日期也会随着改变。
function changeMonth() {

yearObj = document.tableForm.selectYear;
monthObj = document.tableForm.selectMonth;
dayObj = document.tableForm.selectDay;

dayObj.options.length = 0;
var month = monthObj.value;
var year = yearObj.value;
//如果是4,6,9,11月,就有30天
if(month == 4 || month == 6 || month == 9 || month == 11){
for(var i = 1; i <= 30; i++) {
var day = new Option(i,i);
dayObj.options.add(day);
}
}
//如果是2月,则
else if(month == 2) {
if((year%4==0 && year%100!=0) || year%400==0) {
for(var i = 1; i <= 29; i++) {
var day = new Option(i,i);
dayObj.options.add(day);
}
}else {
for(var i = 1; i <= 28; i++) {
var day = new Option(i,i);
dayObj.options.add(day);
}
}
}
//其他月份都是31天
else {
for(var i = 1; i <= 31; i++) {
var day = new Option(i,i);
dayObj.options.add(day);
}
}
}
自己写的比较全js验证,供大家参考 //身份证验证 function checkIdcard(idcard1,showMsg){ var idcard=this.trim(idcard1);// 对身份证号码做处理。去除头尾空格。 var Errors=new Array( "验证通过!", "身份证号码位数不对!", "身份证号码出生日期超出范围或含有非法字符!", "身份证号码校验错误!", "身份证地区非法!" ); var area={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 idcard,Y,JYM; var S,M; var idcard_array = new Array(); idcard_array = idcard.split(""); /*基本校验*/ if(idcard == "" || idcard == null || idcard.length == 0) { if(showMsg==null||showMsg=="") alert("身份证号为空,请输入您的身份证号!"); return false; } /*地区检验*/ if(area[parseInt(idcard.substr(0,2))]==null) { if(showMsg==null||showMsg=="") alert(Errors[4]); return false; } /*身份号码位数及格式检验*/ switch(idcard.length){ case 15: if ( (parseInt(idcard.substr(6,2))+1900) % 4 == 0 || ((parseInt(idcard.substr(6,2))+1900) % 100 == 0 && (parseInt(idcard.substr(6,2))+1900) % 4 == 0 )){ ereg=/^[1-9][0-9]{5}[0-9]{2}((01|03|05|07|08|10|12)(0[1-9]|[1-2][0-9]|3[0-1])|(04|06|09|11)(0[1-9]|[1-2][0-9]|30)|02(0[1-9]|[1-2][0-9]))[0-9]{3}$/;//测试出生日期的合法性 } else { ereg=/^[1-9][0-9]{5}[0-9]{2}((01|03|05|07|08|10|12)(0[1-9]|[1-2][0-9]|3[0-1])|(04|06|09|11)(0[1-9]|[1-2][0-9]|30)|02(0[1-9]|1[0-9]|2[0-8]))[0-9]{3}$/;//测试出生日期的合法性 } if(ereg.test(idcard)){ //alert(Errors[0]+"15"); return true; //15位验证通过 } else { if(showMsg==null||showMsg=="") alert(Errors[2]); return false; } break; case 18: //18位身份号码检测 //出生日期的合法性检查 //闰年月日:((01|03|05|07|08|10|12)(0[1-9]|[1-2][0-9]|3[0-1])|(04|06
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值