问题:在日期框里用户可随意书写日期,但提交时错误日期不能正常保存导致报错。
解决方法:
//20210813判断日期是否输入正确
function IsDate(sm,mystring) {
//var reg = /^(\d{4})-(\d{1,2})-(\d{1,2})$/;
var reg=/(([0-9]{3}[1-9]|[0-9]{2}[1-9][0-9]{1}|[0-9]{1}[1-9][0-9]{2}|[1-9][0-9]{3})-(((0[13578]|1[02])-(0[1-9]|[12][0-9]|3[01]))|((0[469]|11)-(0[1-9]|[12][0-9]|30))|(02-(0[1-9]|[1][0-9]|2[0-8]))))|((([0-9]{2})(0[48]|[2468][048]|[13579][26])|((0[48]|[2468][048]|[3579][26])00))-02-29)/;
var arr = reg.exec(mystring);
var booldate = true;
var sd = mystring.split("-");
if (sd.length == 3) {
if (sd[1] > 12||sd[1]=="") {
com.message('warning', '' + sm + '中输入的月份'+sd[1]+'不存在,请确保日期格式为yyyy-mm-dd且日期存在!');
booldate = false;
} else if (sd[2] > 31||sd[2]=="") {
com.message('warning', '' + sm + '中输入的日期'+sd[2]+'不存在,请确保日期格式为yyyy-mm-dd且日期存在!');
booldate = false;
}else if (sd[0]==""){
com.message('warning', '' + sm + '中输入的年份'+sd[0]+'不存在,请确保日期格式为yyyy-mm-dd且日期存在!');
booldate = false;
}else if(arr==null){
com.message('warning', '请确保' + sm + '中输入的日期格式为yyyy-mm-dd且日期存在(注意闰年2月份)!');
booldate = false;
}
} else {
if (mystring == "") {
booldate = true;
} else {
if (arr != null) {
} else {
com.message('warning', '请确保' + sm + '中输入的日期格式为yyyy-mm-dd且日期存在!');
booldate = false;
}
}
}
return booldate;
}
//将参数传进去就可以
var isdate = false;
isdate = IsDate('求职时间', $('#txtDate').datebox('getValue'));
if (!isdate) return;
加入以上判断后,就可提示错误拦截保存了