基于Asp.net与Javascript控制的日期控件

 更新时间:2010年05月22日 02:42:31   作者:  
使用Asp.net+Javascript控制的日期控件,需要的朋友可以参考下。

控件效果如下:

从左到右:month,day,year

.cs文件初始化这三个下拉列表

复制代码 代码如下:

private void BindBirthDay(int day, int month, int year)
{
int dayNow = day;
int monNow = month;
int yearNow = year;
//binding Month
for (int i = 1; i <= 12; i++)
{
ddlBirMon.Items.Add(new ListItem(i.ToString(), i.ToString()));
}
ddlBirMon.Items[monNow - 1].Selected = true;
//binding Day
int daysOfMonth = DateTime.DaysInMonth(yearNow, monNow);
for (int i = 1; i <= daysOfMonth; i++)
{
ddlBirDay.Items.Add(new ListItem(i.ToString(), i.ToString()));
}
ddlBirDay.Items[dayNow - 1].Selected = true;
//binding Year
for (int i = 20; i > 0; i--)
{
ddlBirYear.Items.Add(new ListItem((yearNow - i).ToString(), (yearNow - i).ToString()));
}
for (int i = 0; i < 20; i++)
{
ddlBirYear.Items.Add(new ListItem((yearNow + i).ToString(), (yearNow + i).ToString()));
}
ddlBirYear.Items.FindByValue(yearNow.ToString()).Selected = true;
}

js代码如下(自己写的,不保证完全正确啊):
复制代码 代码如下:

function ChangeDay() {
var month = document.getElementById("<%=ddlBirMon.ClientID %>");
var year = document.getElementById("<%=ddlBirYear.ClientID %>");
var day = document.getElementById("<%=ddlBirDay.ClientID %>");
if (month.selectedIndex == 3 || month.selectedIndex == 5 || month.selectedIndex == 8 || month.selectedIndex == 10) {
if (day.length == 31) {
if (day.options[30].selected == true) {
day.options[29].selected = true;
}
day.remove(30);
}
}
else{
while (day.length < 31) {
day.add(new Option(day.length+1,day.length+1));
}
}
if (month.selectedIndex == 1) {
if (day.length > 28) {
if (day.selectedIndex == 28) {
day.options[27].selected = true;
}
while (day.length > 28) {
day.remove(day.length - 1);
}
}
var sy = year.options[year.selectedIndex].value;
if ((sy % 4 == 0 && sy % 100 != 0) || (sy % 400==0)) {
day.add(new Option("29", "29"));
}
}
}

相关文章

  • jsp+javascript打造级连菜单的实例代码

    jsp+javascript打造级连菜单的实例代码

    jsp+javascript打造级连菜单的实例代码,需要的朋友可以参考一下
    2013-06-06
  • JavaScript中变量提升与函数提升经典实例分析

    JavaScript中变量提升与函数提升经典实例分析

    这篇文章主要介绍了JavaScript中变量提升与函数提升,结合实例形式分析了JavaScript中的变量提升与函数提升相关原理、使用方法及操作注意事项,需要的朋友可以参考下
    2018-07-07
  • javascript实现分栏显示小技巧附图

    javascript实现分栏显示小技巧附图

    考试页面可以实现隐藏左边的考生信息部分,学了javascript后也能实现这个功能了,下面是实现思路、代码及解效果截图,喜欢的朋友们可以看看
    2014-10-10
  • 基于css3新属性transform及原生js实现鼠标拖动3d立方体旋转

    基于css3新属性transform及原生js实现鼠标拖动3d立方体旋转

    这篇文章主要介绍了基于css3新属性transform及原生js实现鼠标拖动3d立方体旋转 的相关资料,需要的朋友可以参考下
    2016-06-06
  • ES6中解构赋值的语法及用法实例

    ES6中解构赋值的语法及用法实例

    ES6的解构赋值是一种快速方便的方法,可以从数组或对象中提取值并将其赋值给变量,下面这篇文章主要给大家介绍了关于ES6中解构赋值的语法及用法的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2024-04-04
  • JavaScript简写技巧

    JavaScript简写技巧

    这篇文章主要介绍了JavaScript简写技巧,运用简写技巧,可以加快开发速度,让开发工作事半功倍,大家感兴趣的话可以参考本篇文章
    2021-08-08
  • JS+HTML5 canvas绘制验证码示例

    JS+HTML5 canvas绘制验证码示例

    这篇文章主要介绍了JS+HTML5 canvas绘制验证码,结合实例形式分析了HTML5 canvas图形绘制相关操作技巧,需要的朋友可以参考下
    2018-12-12
  • 跟我学习javascript的prototype原型和原型链

    跟我学习javascript的prototype原型和原型链

    跟我学习javascript的prototype原型和原型链,感兴趣的小伙伴们可以参考一下
    2015-11-11
  • BooStrap对导航条的改造实践小结

    BooStrap对导航条的改造实践小结

    这篇文章主要介绍了BooStrap对导航条的改造实践小结的相关资料,本文分步骤介绍的非常详细,具有参考借鉴价值,需要的朋友可以参考下
    2016-09-09
  • js模糊查询实例分享

    js模糊查询实例分享

    本文主要分享了js模糊查询的实现代码,没有接触到后台数据的知识,只是查询当前表格中每一行所包含的关键字。具有一定的参考价值,需要的朋友一起来看下吧
    2016-12-12

最新评论