根据String类型日期算年龄
思路:
- String日期转换成Date类型
- 判断月,日; 如果大于 当前月 并且 大于 当前日,则年减年减1 ;否者 年减年
建议:
3. 设计表结构时,不建议直接用int类型的年龄,改为日期,varchar和date均可,若无特殊要求,最好是varchar
4. 根据需求,前端先判断,输入日期是否满足要求,
5. 展示时,数据在后台获取时可直接将日期转为年龄,再发送前台
前端:jsp页面,代码如下
body:
birthday:<input type="text" name="birthday" "WdatePicker()" ><br>
JavaScript:
//获取输入框日期,字符串格式
var d2 = $("[name='birthday']").val()
//字符串日期 --> date格式
var b2=new Date(d2.replace(/-/g, "\/"));
//获取现在日期,date格式
var d=new Date();
//计算年龄
var age = d.getFullYear()-b2.getFullYear()-((d.getMonth()<= b2.getMonth() && d.getDate()<b2.getDate())?1:0);
alert(age)
if(age < 0){
alert("请重新输入")
}
后端:java代码
//根据出生日期算年龄
public static int age(String s) {
//获取现在日期,Date格式
Date d = new Date();
//字符串日期 --> date格式
SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd");
Date d2;
int age = 0;
try {
d2 = format.parse(s);
age =d.getYear()-d2.getYear()- ((d.getMonth()<= d2.getMonth() && d.getDate()<d2.getDate())?1:0);
} catch (ParseException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return age;
}