js实现一个日期联动下拉菜单

作者:Qihontin 时间:2007-08-04 20:49:00 

内容摘要:这篇文章的主旨是弄清楚如何根据实际需求实现一个联动菜单以及联动菜单的原理,实例是实现一个日期选择下拉菜单。

首先来分析一下日期下拉菜单的需求。建议大家在写任何程序的时候都应该在动手编程之前想清楚自己需要些什么,这样编程才有效率。本文调试环境为IE6/firefox1.5。

年份: 一般来说有一个有效年份,比如说1900年至当前年份才是为效的,这个要根据实际需求来确定,如果是该下拉菜单是用来选择出生年月日还得把最大的年份减到一定的数目,如果有人的生日选择了2005年(即当前的年份),那是不正常的。

月份:没有什么特殊需求,不管是哪一年都是有十二个月。

天数:每个月的天数都可能是不定的,当然这可以根据一定的算法求出来,而它的根据就是当前选择的年份和月份。月份都有一个固定的天数,即一、三、五、七、八、十、十二月是三十一天,而四、六、九、十一月是三十天,二月份要根据当年是否为闰年判断是二十八天还是二十九天。求当月的天数我提出一个比较简单的算法,可以只根据当前的年份和月份就可以求出当月的天数,这会在后边讲一讲思路并将其实现。

好了,现在我们来具体实现这个日期联动下拉菜单。

联动下拉菜单是以两个或多个select元素为单位的,为了让这些菜单更多紧密的工作,我们可以实现一个类用来管理它们的初始化、事件,在这里就使用DateSelector为类名,它有三个属性,分别为年、月、日的下拉菜单,而这三个select元素是由构造函数的参数传进来的,另外为了更灵活地使用它,我们还可以再给DateSelector类的构造函数增加一个(Date对象)或三个参数(int数值),表示初始化的年月日。由于参数个数不定,我们可以不将另外增加的参数写入参数表里,而是在运行时判断arguments对象的length属性来执行不同的操作。arguments对象存储了当前函数的参数信息,可以查阅一下相关的资料比如说《Windows脚本技术》。


<html>

<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<title>如何实现一个日期下拉菜单</title>
<script type="text/javascript">
function DateSelector(selYear, selMonth, selDay)
{
    this.selYear = selYear;
    this.selMonth = selMonth;
    this.selDay = selDay;
}
</script>
</head>
<body>
</body>
</html>

标签:联动菜单,日期,js
0
投稿

猜你喜欢

  • Oracle SQL性能优化系列学习三

    2010-07-23 13:08:00
  • MYSQL数据库实用学习资料之常用命令集合

    2009-03-06 18:12:00
  • CSS布局之浮动(一)两列布局

    2008-08-18 21:24:00
  • 关于SQL Server数据库备份和恢复特性介绍

    2009-02-19 16:57:00
  • [译]Javascript风格要素(一)

    2008-02-28 12:58:00
  • Xml Http抓取数据时乱码问题解决

    2008-04-24 11:16:00
  • 一段查看ASP文件源码的ASP程序

    2007-09-21 12:53:00
  • 数字人整合动网论坛的方法

    2009-05-29 18:23:00
  • Oracle数据库的空间管理技巧

    2010-07-26 13:16:00
  • 下拉列表两级连动的新方法(二)

    2009-06-04 18:22:00
  • [译稿]Web 字体的未来

    2008-07-31 17:50:00
  • SQL Server数据库动态交叉表的参考示例

    2009-01-04 14:44:00
  • 使用 JSON 进行数据传输

    2008-06-15 07:12:00
  • 最新的关键SQL Server漏洞已被微软证实

    2009-03-16 14:31:00
  • text-overflow实现标题省略号功能

    2009-05-19 12:13:00
  • 写给喜欢用DW编写CSS人的一些建议

    2008-05-19 12:09:00
  • 在ASP中使用Oracle数据库技巧

    2008-05-17 11:47:00
  • 带中英文翻译功能的收藏夹

    2008-07-31 11:33:00
  • oracle下一条SQL语句的优化过程(比较详细)

    2010-04-22 16:58:00
  • FrontPage XP设计教程1——站点初建与管理

    2008-10-11 12:13:00
  • asp之家 网络编程 m.aspxhome.com