年月日三下拉框联动

来源:互联网 发布:理光扫描仪软件 编辑:程序博客网 时间:2024/04/29 16:55
  1. <html>
  2. <head>
  3. <title>年月日三下拉框联动</title>
  4. <meta http-equiv='Content-Type' content='text/html; charset=gb2312'>
  5. <meta name='author' content='F.R.Huang(meizz梅花雪)//www.meizz.com'>
  6. </head>
  7. <body>
  8. <form name=form1>
  9. <select name=YYYY onChange="YYYYDD(this.value)">
  10. <option value="">请选择 年</option>
  11. </select>
  12. <select name=MM onChange="MMDD(this.value)">
  13. <option value="">选择 月</option>
  14. </select>
  15. <select name=DD>
  16. <option value="">选择 日</option>
  17. </select>
  18. </form>
  19. <script language="JavaScript"><!--
  20. function YYYYMMDDstart()
  21. {
  22. MonHead = [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31];
  23. //先给年下拉框赋内容
  24. var y = new Date().getFullYear();
  25. for (var i = (y-30); i < (y+30); i++) //以今年为准,前30年,后30年
  26. document.form1.YYYY.options.add(new Option(" "+ i +" 年", i));
  27. //赋月份的下拉框
  28. for (var i = 1; i < 13; i++)
  29. document.form1.MM.options.add(new Option(" " + i + " 月", i));
  30. document.form1.YYYY.value = y;
  31. document.form1.MM.value = new Date().getMonth() + 1;
  32. var n = MonHead[new Date().getMonth()];
  33. if (new Date().getMonth() ==1 && IsPinYear(YYYYvalue)) n++;
  34. writeDay(n); //赋日期下拉框Author:meizz
  35. document.form1.DD.value = new Date().getDate();
  36. }
  37. if(document.attachEvent)
  38. window.attachEvent("onload", YYYYMMDDstart);
  39. else
  40. window.addEventListener('load', YYYYMMDDstart, false);
  41. function YYYYDD(str) //年发生变化时日期发生变化(主要是判断闰平年)
  42. {
  43. var MMvalue = document.form1.MM.options[document.form1.MM.selectedIndex].value;
  44. if (MMvalue == ""){ var e = document.form1.DD; optionsClear(e); return;}
  45. var n = MonHead[MMvalue - 1];
  46. if (MMvalue ==2 && IsPinYear(str)) n++;
  47. writeDay(n)
  48. }
  49. function MMDD(str) //月发生变化时日期联动
  50. {
  51. var YYYYvalue = document.form1.YYYY.options[document.form1.YYYY.selectedIndex].value;
  52. if (YYYYvalue == ""){ var e = document.form1.DD; optionsClear(e); return;}
  53. var n = MonHead[str - 1];
  54. if (str ==2 && IsPinYear(YYYYvalue)) n++;
  55. writeDay(n)
  56. }
  57. function writeDay(n) //据条件写日期的下拉框
  58. {
  59. var e = document.form1.DD; optionsClear(e);
  60. for (var i=1; i<(n+1); i++)
  61. e.options.add(new Option(" "+ i + " 日", i));
  62. }
  63. function IsPinYear(year)//判断是否闰平年
  64. return(0 == year%4 && (year%100 !=0 || year%400 == 0));}
  65. function optionsClear(e)
  66. {
  67. e.options.length = 1;
  68. }
  69. //--></script>
  70. </body>
  71. </html> 
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 笔记本字母键打出数字怎么办 wps打字字上移了怎么办 微信里黑圈里面的白字是怎么办 脖子比脸黑好多怎么办 河南许昌小学生生病办休学怎么办 1岁宝宝内向胆小怎么办 3岁宝宝内向胆小怎么办 数学物理好不喜欢学医怎么办 孩子眉毛太浓了怎么办 小娃一年级成绩太差怎么办 孩子晚上睡得晚怎么办 在深圳买房难小孩读书怎么办 上海小孩读书积分不够怎么办 读书时静不下心怎么办 初中生静不下心读书怎么办 孩子学习静不下心怎么办 退烧后体温35度怎么办 孩子体温34度多怎么办 宝宝感冒咳嗽流鼻涕出汗怎么办 养的小鸡总打架怎么办 小鸡一条腿瘸了怎么办 同窝小斗鸡打架怎么办 夏季羊长的慢怎么办 1岁吃母乳不吃饭怎么办 5个月宝宝黏妈妈怎么办 九个月宝宝不爱吃饭怎么办 20个月宝宝吐了怎么办 十个月的宝宝消化不好怎么办 两岁宝宝不爱喝水怎么办 两岁宝宝不爱喝水吃饭怎么办 两岁的宝宝不爱喝水怎么办 宝宝不爱吃饭不爱喝水怎么办 一多半宝宝爱喝水 不爱吃饭怎么办 1岁宝宝不爱吃饭喝水怎么办 两岁小宝宝不爱吃饭怎么办 4个月小宝宝咳嗽怎么办 3个月小宝宝咳嗽怎么办 2个月小宝宝咳嗽怎么办 8的岁儿童腿不直怎么办 作业盒子选错年级怎么办 两岁x型腿怎么办