JS+HTML语言编写出生日期,年月日列表

年月日列表:要求当年和月列表发生改变时,刷新日列表
原理:
大月:31天
小月:30天
2月:闰年29天,平年28天
知识点:selec列表框的使用,通过options集合的add()方法添加列表项,或者通过select对象的appendChild()添加列表项
闰年判断:(1)能被4整除但是不能被100整除(2)能被400整除

<!doctype html>
<html>
<head>
 <meta charset="utf-8"/>
 <title>年月日列表</title>
<script>
 window.onload=function(){
 var oY=document.getElementById("year");
 var oM=document.getElementById("month");
 var oD=document.getElementById("day");
 //oY.options.add(new Option(1970));
 //oY.appendChild(new Option(1971));
 ini(oY,oM,oD);
 oY.onchange=function(){
 ref(oY,oM,oD);
 }
 oM.onchange=function(){
 ref(oY,oM,oD);
 }
 }
 //任务一:初始化年月日列表框
 function ini(y,m,d){
  for(var i=1970;i<2051;i++){
  y.appendChild(new Option(i));
  }
  for(var i=1;i<13;i++){
  m.appendChild(new Option(i));
  }
  for(var i=1;i<32;i++){
  d.appendChild(new Option(i));
  }
 }
 //任务二:当年、月列表框内容改变时,刷新日列表框
 function ref(y,m,d){
 var yv=y.value;
 var mv=m.value;
 var dv;
 switch(parseInt(mv)){
 case 1:
 case 3:
 case 5:
 case 7:
 case 8:  
 case 10:
 case 12: dv=31;break;
 case 4:
 case 6:
 case 9:
 case 11:dv=30;break;
 case 2:
  if((yv%4==0&&yv%100!=0)||(yv%400==0)){
  dv=29;
  }else{
  dv=28;
  }
  break;
 }
 d.length=0;//清空日列表
 for(var i=1;i<dv+1;i++){
  d.appendChild(new Option(i));
  }
 }
 </script>
</head>
<body>
 <label for="">出生日期:</label>
 <select name="" id="year"></select><select name="" id="month"></select><select name="" id="day"></select></body>
</html>
  • 5
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值