<script>
var m=new Date()
m.setFullYear(2010,10,14)
var age=0
var d = new Date()
var year = d.getFullYear()
var month = d.getMonth() + 1
var day = d.getDate()
alert(year+"-"+month+"-"+day)
if(year>m.getFullYear()){
if(month>=m.getMonth() + 1){
if(day>=m.getDate()){
age=parseInt(year-m.getFullYear())
}else{
age=parseInt(year-m.getFullYear()-1)
}
}else{
age=parseInt(year-m.getFullYear()-1)
}
}else{
alert("0")
}
alert("age="+age)
</script>
//你也可以把以上内容写入方法,出生日期的年月日作为参数传入。注意,月份的算法
根据出生日期计算年龄的公式是:DATAIF函数。输入公式=DATEIF(C2,TODAY(),"Y")即可。
公式说明:DATEIF有3个参数,第一个参数是开始日期,第二个参数是终止日期,第三个参数是比较单位。注意这里“yyyymmdd”这种格式的出生日期不适用这个公式。
第二种方法:TODAY函数。输入公式=(TODAY()-E2)/365即可,如果小数点后面有小数,更改一下数据格式,只保留整数。
公式说明:这个公式比较简单,TODAY()函数得出来的是现在的具体日期,减去出生的具体日期,就是具体的天数,一年有365天,再除以365就可以计算出多少年,即年龄。注意“yyyymmdd”这种格式的出生日期同样也不适用这个公式。
身份证号计算年龄的方法是:
1.要计算年龄,需要用当前的年份减去身份证上的出生年份。我们可以用YEAR函数来取得当前的年份=YEAR(NOW())。
2.18位身份证号从第7位开始的8位数字代表出生日期。出生的年份是从第7位开始的4位数字,用MID函数将出生年份提取出来。
3.将上述两个部分合并,就得到了单元格的最终公式:=YEAR(NOW())-MID(A2,7,4)。
function geb(obj){
return document.getElementById(obj)//引入对象ID,返回某个对象
}
function tmValue(obj)
{
return geb(obj)[geb(obj).selectedIndex].value//引入select的ID,返回select的已选中的项的value值
}
function retAge()
{
var
year=tmValue('optionYear')*1,//取得选中年份的值,并转换为数字
month=tmValue('optionMonth')*1,//取得选中月份的值,并转换为数字
day=tmValue('optionDay')*1//取得选中日的值,并转换为数字
var
birthday=new data(),now=birthday//声明个生日日期变量和现在日期变量,此时两个变量都是现在的系统时间
birthday.setFullYear(year,month,day)//将年月日付给生日日期变量
var fulltime=now-birthday//得到两个日期所距离的毫秒数
//楼下说的很对,要考虑月份,所以我对我的代码作出如下调整
var age=now.getFullYear() - fulltime.getFullYear()//返回距离年
if((now.getMonth()-birthday.getMonth())>0)age+1//如果现在的月份比生日月份大,年龄变量加1
return age//返回计算后的年龄
// return fulltime /1000/60/60/24返回距离多少天
//还有你上面的input 没有 type='text'
//因为是手写的代码,所以可能存在大小写错误,自己改下
}