2011-08-31[年月日3级级联js代码]

function YYYYMMDDstart() {
    document.getElementById("ddlYear").options.add(new Option("请选择", ""));
    document.getElementById("ddlMonth").options.add(new Option("请选择" , ""));
    document.getElementById("ddlDay").options.add(new Option("请选择", ""));
    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++) //以今年为准,前30年,后30年
        document.getElementById("ddlYear").options.add(new Option(" " + i + " 年", i));
    //赋月份的下拉框
    for (var i = 1; i < 13; i++)
        document.getElementById("ddlMonth").options.add(new Option(" " + i + " 月", i));
    document.getElementById("ddlYear").value = y;
    document.getElementById("ddlMonth").value = new Date().getMonth() + 1;
    var n = MonHead[new Date().getMonth()];
    if (new Date().getMonth() == 1 && IsPinYear(YYYYvalue)) n++;
    writeDay(n); //赋日期下拉框Author:meizz
    document.getElementById("ddlDay").value = new Date().getDate();
    $("#ddlYear").val("");
    $("#ddlMonth").val("");
    $("#ddlDay").val("");
}
//if (document.attachEvent)
//    window.attachEvent("onload", YYYYMMDDstart);
//else
//    window.addEventListener('load', YYYYMMDDstart, false);
function YYYYDD(str) //年发生变化时日期发生变化(主要是判断闰平年)
{
    var MMvalue = document.getElementById("ddlMonth").options[document.getElementById("ddlMonth").selectedIndex].value;
    if (MMvalue == "") { var e = document.getElementById("ddlDay"); optionsClear(e); return; }
    var n = MonHead[MMvalue - 1];
    if (MMvalue == 2 && IsPinYear(str)) n++;
    writeDay(n);
}
function MMDD(str) //月发生变化时日期联动
{
    var YYYYvalue = document.getElementById("ddlYear").options[document.getElementById("ddlYear").selectedIndex].value;
    if (YYYYvalue == "") { var e = document.getElementById("ddlDay"); optionsClear(e); return; }
    var n = MonHead[str - 1];
    if (str == 2 && IsPinYear(YYYYvalue)) n++;
    writeDay(n);
}
function writeDay(n) //据条件写日期的下拉框
{
    var e = document.getElementById("ddlDay"); 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;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值