只有年月日的日历(前端代码实现)
来源:互联网 发布:淘宝关联本地商户 编辑:程序博客网 时间:2024/05/23 10:36
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta charset="UTF-8"/> <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" /> <title>JS年月日三级联动下拉框日期选择代码</title> </head> <body> <form name="reg_testdate"> <select name="YYYY" onChange="YYYYDD(this.value)"> <option value="">请选择 年</option> </select> <select name="MM" onChange="MMDD(this.value)"> <option value="">选择 月</option> </select> <select name="DD"> <option value="">选择 日</option> </select> </form> <script language="JavaScript"> function YYYYMMDDstart() { MonHead = [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31]; //先给年下拉框赋内容 var y = new Date().getFullYear(); for (var i = (y - 30); i < (y + 30); i++) //以今年为准,前30年,后30年 document.reg_testdate.YYYY.options.add(new Option(" " + i + " 年", i)); //赋月份的下拉框 for (var i = 1; i < 13; i++) document.reg_testdate.MM.options.add(new Option(" " + i + " 月", i)); document.reg_testdate.YYYY.value = y; document.reg_testdate.MM.value = new Date().getMonth() + 1; var n = MonHead[new Date().getMonth()]; if (new Date().getMonth() == 1 && IsPinYear(YYYYvalue)) n++; writeDay(n); //赋日期下拉框Author:meizz document.reg_testdate.DD.value = new Date().getDate(); } if (document.attachEvent) window.attachEvent("onload", YYYYMMDDstart); else window.addEventListener('load', YYYYMMDDstart, false); function YYYYDD(str) //年发生变化时日期发生变化(主要是判断闰平年) { var MMvalue = document.reg_testdate.MM.options[document.reg_testdate.MM.selectedIndex].value; if (MMvalue == "") { var e = document.reg_testdate.DD; optionsClear(e); return; } var n = MonHead[MMvalue - 1]; if (MMvalue == 2 && IsPinYear(str)) n++; writeDay(n) } function MMDD(str) //月发生变化时日期联动 { var YYYYvalue = document.reg_testdate.YYYY.options[document.reg_testdate.YYYY.selectedIndex].value; if (YYYYvalue == "") { var e = document.reg_testdate.DD; optionsClear(e); return; } var n = MonHead[str - 1]; if (str == 2 && IsPinYear(YYYYvalue)) n++; writeDay(n) } function writeDay(n) //据条件写日期的下拉框 { var e = document.reg_testdate.DD; optionsClear(e); for (var i = 1; i < (n + 1); i++) e.options.add(new Option(" " + i + " 日", i)); } function IsPinYear(year) //判断是否闰平年 { return (0 == year % 4 && (year % 100 != 0 || year % 400 == 0)); } function optionsClear(e) { e.options.length = 1; } </script> </body></html>
阅读全文
0 0
- 只有年月日的日历(前端代码实现)
- 可用的年月日到年月日(前端代码实现,一共三个文件)
- 年月日下拉日历的JS
- C# 用代码实现年月日的绑定
- 前端实现只显示年月日
- JavaScript实现日历控件(只有年月)
- PHP实现的简单日历代码
- jquery日历的开发和实现代码
- iOS简易日历的代码实现分析
- 实现年月日下拉菜单的javascript代码示例
- 实现年月日下拉菜单的javascript代码示例
- 自己写的一个日历年月日的js类
- 如何样让datetime类型的数据只有年月日
- C# 根据出生日期(年月日)计算年龄的代码
- 日历代码的完整版
- 年月日的数据实现方式
- 分别实现数字时钟和日历的js代码
- MySQL存入时间只有年月日
- 谈谈css的伪类和伪元素
- 《Java源码分析》:ReadWriteLock(第一部分)
- 求任意多边形的面积&HDU-2036 改革春风吹满地
- Java中this,super关键字
- Android面试基础题详解1
- 只有年月日的日历(前端代码实现)
- Activity退出动画无效
- Java内存结构及参数的传递
- d3.js-svg图形基础
- onclick事件总结
- Android代码混淆之混淆规则
- React Native 集成分享第三方登录功能分享第三方登录模块开发(Android)
- 存储结构和磁盘划分(基于RedHat7)
- 使用XML方式配置log4j日志