js实现日期级联效果
js实现日期级联效果
发布时间:2016-12-30 来源:查字典编辑
摘要:复制代码代码如下:请选择年选择月选择日functionwindow.onload(){strYYYY=document.form1.YYYY...

复制代码 代码如下:

<div>

<select name="YYYY" onchange="YYYYMM(this.value)">

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

</select>

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

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

</select>

<select name="DD">

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

</select>

</div>

<script language="JavaScript">

function window.onload() {

strYYYY = document.form1.YYYY.outerHTML;

strMM = document.form1.MM.outerHTML;

strDD = document.form1.DD.outerHTML;

MonHead = [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31];

//先给年下拉框赋内容

var y = new Date().getFullYear();

var str = strYYYY.substring(0, strYYYY.length - 9);

for (var i = (y - 30); i < (y + 30); i++) //以今年为准,前30年,后30年

{

str += "<option value='" + i + "'> " + i + " 年" + "</option>rn";

}

document.form1.YYYY.outerHTML = str + "</select>";

//赋月份的下拉框

var str = strMM.substring(0, strMM.length - 9);

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

str += "<option value='" + i + "'> " + i + " 月" + "</option>rn";

}

document.form1.MM.outerHTML = str + "</select>";

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();

}

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

{

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

if (MMvalue == "") { DD.outerHTML = strDD; 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 (str == "") { DD.outerHTML = strDD; return; }

var n = MonHead[str - 1];

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

writeDay(n)

}

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

{

var s = strDD.substring(0, strDD.length - 9);

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

s += "<option value='" + i + "'> " + i + " 日" + "</option>rn";

document.form1.DD.outerHTML = s + "</select>";

}

function IsPinYear(year)//判断是否闰平年

{

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

}

推荐文章
猜你喜欢
附近的人在看
推荐阅读
拓展阅读
相关阅读
网友关注
最新Javascript教程学习
热门Javascript教程学习
编程开发子分类