根据datetimepicker选择的日期计算年龄

来源:互联网 发布:维棠下载器 mac版 编辑:程序博客网 时间:2024/06/06 08:49

首先上图看一下实现的效果:


html:(切记input加上value)

    <div class="form-group">      <div class="col-md-4 control-label">        <label>出生日期:</label>      </div>      <div class="controls col-md-5">        <input class="form-control calendar-item" name="birthday" type="text" id="birthday" value={{ activityMember.birthday|date('Y-m-d') }} readonly="true">        <i class="es-icon es-icon-calendar text-xlg"></i>      </div>      <div class="text-left color-gray">        <span class="mlm">年龄:</span><input class="js-get-age" type="text" name="age" value=""readonly="true">            </div>    </div>

js:

  $('#birthday').change(function(){    var strBirthday = $('#birthday').val();    $('.js-get-age').val(jsGetAge(strBirthday));  })
  function jsGetAge(strBirthday){             var returnAge;      var strBirthdayArr=strBirthday.split("-");      var birthYear = strBirthdayArr[0];      var birthMonth = strBirthdayArr[1];      var birthDay = strBirthdayArr[2];            d = new Date();      var nowYear = d.getFullYear();      var nowMonth = d.getMonth() + 1;      var nowDay = d.getDate();            if(nowYear == birthYear){        returnAge = 0;//同年 则为0岁      }      else{        var ageDiff = nowYear - birthYear ; //年之差        if(ageDiff > 0){          if(nowMonth == birthMonth) {            var dayDiff = nowDay - birthDay;//日之差            if(dayDiff < 0)            {              returnAge = ageDiff - 1;            }            else            {              returnAge = ageDiff ;            }        }          else          {            var monthDiff = nowMonth - birthMonth;//月之差            if(monthDiff < 0)            {              returnAge = ageDiff - 1;            }            else            {              returnAge = ageDiff ;            }          }        }        else        {          returnAge = -1;//返回-1 表示出生日期输入错误 晚于今天        }      }        return returnAge;//返回周岁年龄       }  


总结一下就是:

1,给datepicker加一个change事件;

2,执行计算年龄的function;

3,将返回的周岁数赋给要输出的标签里面。






0 0
原创粉丝点击