js实现年月日表单三级联动

前端之家收集整理的这篇文章主要介绍了js实现年月日表单三级联动前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

用Html实现人人网注册界面 ,Js实现生日栏表单三级联动

1. 效果

2.HTML代码部分

Meta charset="UTF-8"> 人人网日期表单联动

<table align="center" height = "500">

注册邮箱: 注册或者 注册<tr><td>创建密码: </td><td><input type = "password" name = "password"/></td></tr>

<tr><td>真实姓名: </td><td><input type = "password" name = "name"/></td>

<tr><td align="right">性别: </td><td>男<input type = "radio" value = "male" name = "gender"/>
女<input type = "radio" value = "female" name = "gender"/></td></tr>

<tr><td align="right">生日: </td><td>

<div id="Box">
<select name="sel1" id="sel1">
<option value="year">年

<tr><td align="right">我现在: </td>
<td><select name = "subject">
<option value = "xu">正在上学
<option value = "cz">工作
<option value = "gz">赋闲
<option value = "bk">经商

<tr><td></td><td> <a href="https://www.baidu.com"&gt;看不清换一张
</td></tr>
<tr><td>验证码:</td><td><input type = "password" name = "yanzheng"/></td></tr>
<tr><td></td><td><a href="https://www.baidu.com"&gt; </td></tr>
</table>

3.JavaScript代码

//生成日期 function creatDate() { //生成1900年-2100年 for(var i = 2016; i >= 1950; i--) { //创建select项 var option = document.createElement('option'); option.setAttribute('value',i); option.innerHTML = i; sel1.appendChild(option); } //生成1月-12月 for(var i = 1; i <=12; i++){ var option1 = document.createElement('option'); option1.setAttribute('value',i); option1.innerHTML = i; sel2.appendChild(option1); } //生成1日—31日 for(var i = 1; i <=31; i++){ var option2 = document.createElement('option'); option2.setAttribute('value',i); option2.innerHTML = i; sel3.appendChild(option2); } } creatDate(); //保存某年某月的天数 var days;

//年份点击 绑定函数
sel1.onclick = function()
{
//月份显示默认值
sel2.options[0].selected = true;
//天数显示默认值
sel3.options[0].selected = true;
}
//月份点击 绑定函数
sel2.onclick = function()
{
//天数显示默认值
sel3.options[0].selected = true;
//计算天数的显示范围
//如果是2月
if(sel2.value == 2)
{
//判断闰年
if((sel1.value % 4 === 0 && sel1.value % 100 !== 0) || sel1.value % 400 === 0)
{
days = 29;
}
else
{
days = 28;
}
//判断小月
}else if(sel2.value == 4 || sel2.value == 6 ||sel2.value == 9 ||sel2.value == 11){
days = 30;
}else{
days = 31;
}

//<a href="/tag/zengjia/" target="_blank" class="keywords">增加</a>或<a href="/tag/shanchu/" target="_blank" class="keywords">删除</a>天数
//如果是28天,则<a href="/tag/shanchu/" target="_blank" class="keywords">删除</a>29、30、31天(即使他们不存在也不报错)
if(days == 28){
 sel3.remove(31);
 sel3.remove(30);
 sel3.remove(29);
}
//如果是29天
if(days == 29){
 sel3.remove(31);
 sel3.remove(30);
 //如果第29天不存在,则<a href="/tag/tianjia/" target="_blank" class="keywords">添加</a>第29天
 if(!sel3.options[29]){
  sel3.add(new Option('29','29'),null)
 }
}
//如果是30天
if(days == 30){
 sel3.remove(31);
 //如果第29天不存在,则<a href="/tag/tianjia/" target="_blank" class="keywords">添加</a>第29天
 if(!sel3.options[29]){
  sel3.add(new Option('29',null)
 }
 //如果第30天不存在,则<a href="/tag/tianjia/" target="_blank" class="keywords">添加</a>第30天
 if(!sel3.options[30]){
  sel3.add(new Option('30','30'),null)
 }
}
//如果是31天
if(days == 31){
 //如果第29天不存在,则<a href="/tag/tianjia/" target="_blank" class="keywords">添加</a>第29天
 if(!sel3.options[29])
 {
  sel3.add(new Option('29',null)
 }
 //如果第30天不存在,则<a href="/tag/tianjia/" target="_blank" class="keywords">添加</a>第30天
 if(!sel3.options[30])
 {
  sel3.add(new Option('30',null)
 }
 //如果第31天不存在,则<a href="/tag/tianjia/" target="_blank" class="keywords">添加</a>第31天
 if(!sel3.options[31])
 {
  sel3.add(new Option('31','31'),null)
 }
}

}

//结果显示 设置好日期时间后 弹窗通知
Box.onclick = function()
{
//当年、月、日都已经为设置值时
if(sel1.value !='year' && sel2.value != 'month' && sel3.value !='day')
{
alert("日期时间已经设定好");
}
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。

猜你在找的JavaScript相关文章