DropDownList自动生成年月日

aspx页面上有三个dropdownlist控件,

dropdownlist1 表示年,dropdownlist2表示月,dropdownlist3表示天; 
注意用将这三个dropdownlist控件的autopostback属性设为true。

用户能够方便地选择年月日,并且每月的日期会随着用户选择不同的年,月而发生相应的变化

代码直接复制过去即可使用

前台代码

<div>

<asp:DropDownList ID="DropDownList1" runat="server" AutoPostBack="True"

onselectedindexchanged="DropDownList1_SelectedIndexChanged">

</asp:DropDownList>

<asp:DropDownList ID="DropDownList2" runat="server" AutoPostBack="True"

onselectedindexchanged="DropDownList2_SelectedIndexChanged1">

</asp:DropDownList>

<asp:DropDownList ID="DropDownList3" runat="server">

</asp:DropDownList>

</div>

后台代码

protected void Page_Load(object sender, EventArgs e)

{

DateTime tnow = DateTime.Now;//现在时间

ArrayList alyear = new ArrayList();

int i;

for (i = 2002; i <= 2010; i++)

alyear.Add(i);

ArrayList almonth = new ArrayList();

for (i = 1; i <= 12; i++)

almonth.Add(i);

if (!this.IsPostBack)

{

DropDownList1.DataSource = alyear;

DropDownList1.DataBind();//绑定年

//选择当前年

DropDownList1.SelectedValue = tnow.Year.ToString();

DropDownList2.DataSource = almonth;

DropDownList2.DataBind();//绑定月

//选择当前月

DropDownList2.SelectedValue = tnow.Month.ToString();

int year, month;

year = Int32.Parse(DropDownList1.SelectedValue);

month = Int32.Parse(DropDownList2.SelectedValue);

binddays(year, month);//绑定天

//选择当前日期

DropDownList3.SelectedValue = tnow.Day.ToString();

}

}

//判断闰年

private bool checkleap(int year)

{

if ((year % 4 == 0) && (year % 100 != 0) || (year % 400 == 0))

return true;

else return false;

}

//绑定每月的天数

private void binddays(int year, int month)

{

int i;

ArrayList alday = new ArrayList();

switch (month)

{

case 1:

case 3:

case 5:

case 7:

case 8:

case 10:

case 12:

for (i = 1; i <= 31; i++)

alday.Add(i);

break;

case 2:

if (checkleap(year))

{

for (i = 1; i <= 29; i++)

alday.Add(i);

}

else

{

for (i = 1; i <= 28; i++)

alday.Add(i);

}

break;

case 4:

case 6:

case 9:

case 11:

for (i = 1; i <= 30; i++)

alday.Add(i);

break;

}

DropDownList3.DataSource= alday;

DropDownList3.DataBind();

}

//选择年

protected void DropDownList1_SelectedIndexChanged(object sender, EventArgs e)

{

int year, month;

year = Int32.Parse(DropDownList1.SelectedValue);

month = Int32.Parse(DropDownList2.SelectedValue);

binddays(year, month);

}

//选择月

protected void DropDownList2_SelectedIndexChanged1(object sender, EventArgs e)

{

int year, month;

year = Int32.Parse(DropDownList1.SelectedValue);

month = Int32.Parse(DropDownList2.SelectedValue);

binddays(year, month);

}

comboBox控件自动生成年月日

//判断闰年

private bool checkleap(int year)

{

if ((year % 4 == 0) && (year % 100 != 0) || (year % 400 == 0))

return true;

else return false;

}

//绑定每月的天数

private void binddays(int year, int month)

{

int i;

ArrayList alday = new ArrayList();

switch (month)

{

case 1:

case 3:

case 5:

case 7:

case 8:

case 10:

case 12:

for (i = 1; i <= 31; i++)

alday.Add(i);

break;

case 2:

if (checkleap(year))

{

for (i = 1; i <= 29; i++)

alday.Add(i);

}

else

{

for (i = 1; i <= 28; i++)

alday.Add(i);

}

break;

case 4:

case 6:

case 9:

case 11:

for (i = 1; i <= 30; i++)

alday.Add(i);

break;

}

this.comboBox3.DataSource = alday;

}

private void Form1_Load(object sender, EventArgs e)

{

//绑定年

ArrayList alyear = new ArrayList();

int i;

for (i = 1900; i <= 2099; i++)

alyear.Add(i);

this.comboBox1.DataSource = alyear;

//绑定月

ArrayList almonth = new ArrayList();

for (i = 1; i <= 12; i++)

almonth.Add(i);

this.comboBox2.DataSource = almonth;

int year, month;

year = Int32.Parse(this.comboBox1.SelectedValue.ToString());

month = Int32.Parse(this.comboBox2.SelectedValue.ToString());

binddays(year, month);//绑定天

}

private void comboBox1_SelectedIndexChanged(object sender, EventArgs e)

{

int year, month;

year = Int32.Parse(this.comboBox1.SelectedValue.ToString());

month = 1;

binddays(year, month);

}

private void comboBox2_SelectedIndexChanged(object sender, EventArgs e)

{

int year, month;

year = Int32.Parse(this.comboBox1.SelectedValue.ToString());

month = Int32.Parse(this.comboBox2.SelectedValue.ToString());

binddays(year, month);

}

DropDownList自动生成年月日的更多相关文章

  1. 《音乐商店》第4集:自动生成StoreManager控制器

    一.自动生成StoreManager控制器 二.查看 StoreManager 控制器的代码 现在,Store Manager 控制器中已经包含了一定数量的代码,我们从头到尾重新过一下. 1.访问数据 ...

  2. MySql主键自动生成,表、实体、C#调用方法

    1.表:mysql建表语句 DROP TABLE IF EXISTS `keycode`; CREATE TABLE `keycode` ( `Id` ) NOT NULL AUTO_INCREMEN ...

  3. [原创]超强C#图片上传,加水印,自动生成缩略图源代码

    <%@ Page Language=“C#“ AutoEventWireup=“true“ %> <%@ Import Namespace=“System“ %> <%@ ...

  4. SQL Server镜像自动生成脚本

    SQL Server镜像自动生成脚本 镜像的搭建非常繁琐,花了一点时间写了这个脚本,方便大家搭建镜像 执行完这个镜像脚本之后,最好在每台机器都绑定一下hosts文件,不然的话,镜像可能会不work 1 ...

  5. 使用mybatis-generator在自动生成Model类和Mapper文件

    使用mybatis-generator插件可以很轻松的实现mybatis的逆向工程,即,能通过表结构自动生成对应的java类及mapper文件,可以大大提高工作效率,并且它提供了很多自定义的设置可以应 ...

  6. 使用python自动生成docker nginx反向代理配置

    由于在测试环境上用docker部署了多个应用,而且他们的端口有的相同,有的又不相同,数量也比较多,在使用jenkins发版本的时候,不好配置,于是想要写一个脚本,能在docker 容器创建.停止的时候 ...

  7. 9.1.3 .net framework通过业务逻辑层自动生成WebApi的做法

    首先需要说明的是这是.net framework的一个组件,而不是针对.net core的.目前工作比较忙,因此.net core的转换正在编写过程中,有了实现会第一时间贴出来. 接下来进入正题.对于 ...

  8. 9.1.2 asp.net core 自动生成组合查询

    在做系统的时候,经常遇到前台录入一大堆的查询条件,然后点击查询提交后台,在Controller里面生成对应的查询SQL或者表达式,数据库执行再将结果返回客户端. 例如如下页面,输入三个条件,日志类型. ...

  9. mybatis-generator-gui--一个mybatis代码自动生成界面工具

    mybatis-generator-gui是什么 介绍mybatis-generator-gui之前,有必要介绍一下什么是mybatis generator(熟悉的同学可以跳过这一节).我们都知道,通 ...

随机推荐

  1. App自动更新之通知栏下载

    见证过博客园的多次升级,你也希望你的软件通过更新发布新特性通知用户吧,是的.这篇文章是android开发人员的必备知识,是我特别为大家整理和总结的,不求完美,但是有用. 1.设计思路,使用Versio ...

  2. Java中的数据类型及相互转换方法

    本文主要讲解两个部分: 一.Java中的数据类型有哪些? 二.数字类型和字符串类型相互转换的方法? 一.Java中的数据类型有哪些: Java中的数据类型有:基本数据类型和引用数据类型: 基本数据类型 ...

  3. Let it Bead

    http://poj.org/problem?id=2409 // File Name: poj2409.cpp // Author: bo_jwolf // Created Time: 2013年1 ...

  4. redis学习心得之三-【java操作redis】

    今天主要是讲讲java对redis的操作,来段代码掩饰下基本操作即可明白. java调用你需要下载jedis.jar包 下载网址:https://github.com/xetorthio/jedis/ ...

  5. Solr与Tomcat的整合

    solr与tomcat整合有两种方法: 方法一:其整合步骤如下: 1.将solr中的example中的solr拷贝到要作为服务器的位置(我当前创建的目录为D:\Develop\solr\home) 2 ...

  6. [ArcGIS所需的补丁]ArcGIS 10.2.2 for Desktop联系Oracle(2014年10上个月发布)数据库崩溃

    环境的叙述性说明: ArcGIS 10.2.2 for Desktop.Oracle12.1.0.2 RAC 这仅仅是用户当时环境描写叙述.可是导致该问题的解决办法还包含很多其它的环境! 问题描写叙述 ...

  7. MYSQL 体系结构图-unzip_LRU

  8. Enterprise Architect使用教程

    一.Enterprise Architect简介 Enterprise Architect是一个对于软件系统开发有着极好支持的CASE软件(Computer Aided Software Engine ...

  9. 再回首,Java温故知新——开篇说明

    不知不觉在IT界从业2年了,两年时间足够一个人成长很多,当然也会改变很多事.在这两年时间里,随着对技术的深入了解,知识面的拓展以及工作难度的增大,渐渐的感觉自己技术方面根基不稳,多数问题也只是做到知其 ...

  10. 第一篇:数据库需求与ER建模

    前言 在数据库建设过程中,哪一步最重要?绝大多数资料会告诉你,是需求分析阶段.这一步的好坏甚至直接决定数据库项目的成败. 需求分析阶段,也被称为ER建模(entity-relationship mod ...