Asp.Net教程,WinForm教程,Asp.Net MVC,vs2008教程,vs2010教程,Silverlight技术,源码下载,Asp.Net视频教程
全站热门标签
vs2010 Silverlight 存储过程 水晶报表 ADO.NET JavaScript LINQ AjaxPro DataGridView 面向对象 Extjs GridView XML DevExpress HTML教程 Oracle jQuery 分页 GDI+ Visual C++2010 MySQL Office2010 WPF MVC Dojo WCF4.0 VB.NET Sql2005 textbox cookie WCF WinForm Discuz!NT SQL经典语句 T-SQL checkbox ASPxGridView F# asp.net SQL VS2008新特性 DropDownList Access TreeView Ajax VS2008 页面执行时间 Flex 字符串 回调 VB2005 DataSet C#时间 ASP.NET性能优化 用户在线检测 动画
尚未分类 LINQ教程 Enterprise技术 性能优化/调试 水晶报表与打印 安全与加密 图形图像 文件处理 基础教程 Web Services 内置对象 控件示例 正则表达式\采集 ADO.NET 缓存\泛型\线程 XML技术 Url重写\静态页 vs2008综合教程
当前位置: 主页 > ASP.NET教程 > 尚未分类 >

asp.net结合js做年月日三级联动

时间:2010-05-16 21:52来源:百度空间 作者:admin 点击:

<HTML>

    <HEAD>

        <title>年月日三联动下拉框</title>

        <meta http-equiv='Content-Type' content='text/html; charset=gb2312'>

        <meta name='author' content='http://singlepine.cnblogs.com/'>

    </HEAD>

    <body>

        <form name="form1">

            <select name="YYYY" id="YYYY" onChange="YYYYDD(this.value)">

                <option value="" selected>请选择 </option>年

            </select>

            年

            <select name="MM"  id="MM" onChange="MMDD(this.value)">

                <option value="" selected>选择</option>

            </select>

            月

            <select name="DD" id="DD">

                <option value="" selected>选择 </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-100); i <= y; i++) //以今年为准,前100年
                    document.form1.YYYY.options.add(new Option(" "+ i, i));

                //赋月份的下拉框

                for (var i = 1; i < 13; i++)

                    document.form1.MM.options.add(new Option(" " + i, i));

                document.form1.YYYY.value = y;

                document.form1.MM.value = new Date().getMonth() + 1;

                var n = MonHead[new Date().getMonth()];

                if (new Date().getMonth() ==1 && IsPinYear(YYYYvalue)) n++;

                    writeDay(n); //赋日期下拉框

                document.form1.DD.value = new Date().getDate();

            }

            if(document.attachEvent)

                window.attachEvent("onload", YYYYMMDDstart);

            else

                window.addEventListener('load', YYYYMMDDstart, false);

            function YYYYDD(str) //年发生变化时日期发生变化(主要是判断闰平年)

            {

                var MMvalue = document.form1.MM.options[document.form1.MM.selectedIndex].value;

                if (MMvalue == ""){ var e = document.form1.DD; optionsClear(e); return;}

                var n = MonHead[MMvalue - 1];

                if (MMvalue ==2 && IsPinYear(str)) n++;

                    writeDay(n)

            }

            function MMDD(str) //月发生变化时日期联动

            {

                var YYYYvalue = document.form1.YYYY.options[document.form1.YYYY.selectedIndex].value;

                if (YYYYvalue == ""){ var e = document.form1.DD; optionsClear(e); return;}

                var n = MonHead[str - 1];

                if (str ==2 && IsPinYear(YYYYvalue)) n++;

                    writeDay(n)

            }

            function writeDay(n) //据条件写日期的下拉框

            {

                var e = document.form1.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>

 

------------------------------------------------------------

后台获取时:可以通过 Request["YYYY"].ToString() ; Request["MM"].ToString() ; Request["DD"].ToString();

这样分别获取年月日

 

/***  如果从数据库获取 年月日 用此种方式显示出来 代码如下**/

 

<html>

<head>

</head>

<script language="JavaScript"><!--
            function YYYYMMDDstart()
            {
                MonHead = [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31];

                //先给年下拉框赋内容
                //var y   = new Date().getFullYear();
                var y=<%=nian.Value %>;  //通过HiddenField 控件为年赋值
                for (var i = (y-100); i <= y; i++) //以今年为准,前100年
                    document.form1.YYYY.options.add(new Option(" "+ i, i));

                //赋月份的下拉框
                for (var i = 1; i < 13; i++)
                    document.form1.MM.options.add(new Option(" " + i, i));

                document.form1.YYYY.value = y;
               // document.form1.MM.value = new Date().getMonth() + 1;
               document.form1.MM.value =<%=yue.Value %>;  //通过HiddenField 控件为月赋值
                var n = MonHead[new Date().getMonth()];
                if (new Date().getMonth() ==1 && IsPinYear(YYYYvalue)) n++;
                    writeDay(n); //赋日期下拉框
                //document.form1.DD.value = new Date().getDate();
                document.form1.DD.value = <%=ri.Value %>;  //通过HiddenField 控件为日赋值
            }
            if(document.attachEvent)
                window.attachEvent("onload", YYYYMMDDstart);
            else
                window.addEventListener('load', YYYYMMDDstart, false);
            function YYYYDD(str) //年发生变化时日期发生变化(主要是判断闰平年)
            {
                var MMvalue = document.form1.MM.options[document.form1.MM.selectedIndex].value;
                if (MMvalue == ""){ var e = document.form1.DD; optionsClear(e); return;}
                var n = MonHead[MMvalue - 1];
                if (MMvalue ==2 && IsPinYear(str)) n++;
                    writeDay(n)
            }
            function MMDD(str) //月发生变化时日期联动
            {
                var YYYYvalue = document.form1.YYYY.options[document.form1.YYYY.selectedIndex].value;
                if (YYYYvalue == ""){ var e = document.form1.DD; optionsClear(e); return;}
                var n = MonHead[str - 1];
                if (str ==2 && IsPinYear(YYYYvalue)) n++;
                    writeDay(n)
            }
            function writeDay(n) //据条件写日期的下拉框
            {
                var e = document.form1.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>

<table width="100%">

 <tr>
                    <td height="30" class="Font8"><div align="left">生&nbsp;&nbsp;&nbsp;&nbsp;日:</div></td>
                    <td class="Font2"><div align="left">
                      <select name="YYYY" id="YYYY" onChange="YYYYDD(this.value)">
                <option value="" selected>请选择 </option>年
            </select>
            年
            <select name="MM" id="MM" onChange="MMDD(this.value)">
                <option value="" selected>选择</option>
            </select>
            月
            <select name="DD" id="DD">
                <option value="" selected>选择 </option>
            </select>
           日<asp:HiddenField ID="nian" runat="server" /><asp:HiddenField ID="yue" runat="server" /><asp:HiddenField ID="ri" runat="server" />

                      </span></div></td>
                  </tr>

</table>

</body>

</html>

注:这里用 HiddenField 控件分别获取 数据库中的记录。并通过js赋给年月日控件

(责任编辑:admin)
Tags:三级联动
责任编辑:admin
返回顶部
------分隔线----------------------------
推荐内容
骆驼户外男 真皮磨砂日常休闲鞋 低帮 2011秋冬新款 专柜正品特价 骆驼户外男 真皮磨砂日常休闲鞋 低帮 2011秋冬新款 专柜正品特价