js文件

SYT="-请选择年份-";
SMT="-请选择月份-";
SDT="-请选择日期-";
BYN=50;//年份范围往前50年
AYN=5;//年份范围往后0年
function YMDselect(){
this.SelY=document.getElementsByName(arguments[0])[0];
this.SelM=document.getElementsByName(arguments[1])[0];
this.SelD=document.getElementsByName(arguments[2])[0];
this.DefY=this.SelD?arguments[3]:arguments[2];
this.DefM=this.SelD?arguments[4]:arguments[3];
this.DefD=this.SelD?arguments[5]:arguments[4];
this.SelY.YMD=this;
this.SelM.YMD=this;
this.SelY.onchange=function(){YMDselect.SetM(this.YMD)};
if(this.SelD)this.SelM.onchange=function(){YMDselect.SetD(this.YMD)};
YMDselect.SetY(this)
};
//设置年份
YMDselect.SetY=function(YMD){
dDate = new Date();
dCurYear = dDate.getFullYear();
YMD.SelY.options.add(new Option(SYT,'0'));
for(i = dCurYear+AYN; i>(dCurYear-BYN); i--){
YMDYT=i+'年';
YMDYV=i;
OptY = new Option(YMDYT,YMDYV);
YMD.SelY.options.add(OptY);
if(YMD.DefY==YMDYV) OptY.selected=true
}
YMDselect.SetM(YMD)
};
//设置月份
YMDselect.SetM=function(YMD){
YMD.SelM.length = 0;
YMD.SelM.options.add(new Option(SMT,'0'));
if(YMD.SelY.value>0){
for(var i=1;i<=12;i++){
YMDMT=i+'月';
YMDMV=i;
OptM=new Option(YMDMT,YMDMV);
YMD.SelM.options.add(OptM);
if(YMD.DefM==YMDMV) OptM.selected=true
}
}
if(YMD.SelD)YMDselect.SetD(YMD)
};
//设置日期
YMDselect.SetD=function(YMD){
YI=YMD.SelY.value;
MI=YMD.SelM.value;
YMD.SelD.length = 0;
YMD.SelD.options.add(new Option(SDT,'0'));
if(YI>0 && MI>0){
dPrevDate = new Date(YI, MI, 0);
daysInMonth=dPrevDate.getDate();
for (d = 1; d <= parseInt(daysInMonth); d++) {
YMDDT=d+'日';
YMDDV=d;
OptD=new Option(YMDDT,YMDDV);
YMD.SelD.options.add(OptD);
if(YMD.DefD==YMDDV)OptD.selected=true
}
}
}

html文件

<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>js年月日三级联动</title>
<script src ="js\YYYYMMDDClass.js"></script>
</head> <body > <form action="" style="" method="get">
<span>Birthday: </span>
<select name="year"></select>
<select name="month"></select>
<select name="day"></select>
<br>
<button type="submit" value="submit">submit</button>
<script>
/**
* 年月联动
* new YMDselect('year','month');
* new YMDselect('year','month',2010);//默认2010
*new YMDselect('year','month',2010,2);//2010 2
* */ /**
* 年月日联动
* new YMDselect('year','month','day1');
*new YMDselect('year','month','day1',2020);默认20020年
* new YMDselect('year','month','day1',2020,6);默认20020年6月
* new YMDselect('year','month','day',2020,6,22); 默认20020年6月22日
* */
new YMDselect('year','month','day'); </script> </form>
</body>
</html>

JavaScript 用法

1.js文件外联

<head>
<script src ="js\YYYYMMDDClass.js"></script>
</head>

2.直接用

<head>
<script>
alert("我的第一个 JavaScript");
</script>
</head>

3.在body中用

<!DOCTYPE html>
<html>
<body>
.
.
<script>
document.write("<h1>这是一个标题</h1>");
document.write("<p>这是一个段落</p>");
</script>
.
.
</body>
</html>

更多用法请访问W3CSchool

JS 实现的年月日三级联动的更多相关文章

  1. JS年月日三级联动下拉框日期选择代码

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  2. JS实现年月日三级联动+省市区三级联动+国家省市三级联动

    开篇随笔:最近项目需要用到关于年月日三级联动以及省市区三级联动下拉选择的功能,于是乎网上搜了一些做法,觉得有一些只是给出了小的案例或者只有单纯的js还不完整,却很难找到详细的具体数据(baidu搜索都 ...

  3. 利用select实现年月日三级联动的日期选择效果

    × 目录 [1]演示 [2]规划 [3]结构生成[4]算法处理 前面的话 关于select控件,可能年月日三级联动的日期选择效果是最常见的应用了.本文是选择框脚本的实践,下面将对日期选择效果进行详细介 ...

  4. 时间操作(JavaScript版)—年月日三级联动(默认显示系统时间)

    版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/wangshuxuncom/article/details/35263317         这个功能 ...

  5. js实现年月日三级联动

    当我们注册一个qq的时候,会看到一个三级年月日的联动菜单,下面简单介绍. <!doctype html> <html lang="en"> <head ...

  6. js 实现全国省市区三级联动

    效果: index.html <!DOCTYPE html> <html> <head> <meta charset="utf-8" /& ...

  7. js之省市区(县)三级联动效果

    省市区(县)三级联动效果,是我们软件开发比较常用的,特别是对一些crm,erp之类,当然也包括其他的后台管理系统,基本都涉及到,今天贴出这个常用的,方便个人复用和大家使用 <!DOCTYPE h ...

  8. HTML5 UI 控件Mobiscroll的使用(年月日三级联动)

    概述: 遇到制作一个html5界面,需要选择年月日,其实这个功能很常用.一般我们都是网上找,之前也没有收藏一个自己常用的,今天发现一个不错的库.特此记录一下使用过程,以便以后遇到了方面查阅. 1.官方 ...

  9. jQuery:年月日三级联动

    <%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default3.aspx.cs ...

随机推荐

  1. HiJson(Json格式化工具)64位中文版下载 v2.1.2

    链接:https://pan.baidu.com/s/15gMvig15iUjpqSX7nUZ-5Q 密码:8086

  2. 0513JS数组的定义、遍历、添加

    |数组|-定义方式|--1.new Array();|----空数组|------var attr = new Array();|------lenght:0|------_proto_: Array ...

  3. NetCore版RPC框架NewLife.ApiServer

    微服务和消息队列的基础都是RPC框架,比较有名的有WCF.gRPC.Dubbo等,我们的NewLife.ApiServer建立在网络库NewLife.Net之上,支持.Net Core,追求轻量级和高 ...

  4. Java NIO Channel通道

    原文链接:http://tutorials.jenkov.com/java-nio/channels.html Java NIO Channel通道和流非常相似,主要有以下几点区别: 通道可以读也可以 ...

  5. Sublime Text 3安装SFTP插件

    前言: 最近在学习网页设计,陆续接触到了HTML.CSS和JavaScript,写的代码越来越多了,也越来越感觉到将代码上传到服务器上的流程太繁琐了.一开始我是用虚拟主机提供的控制面板下载上传网页代码 ...

  6. tkinter中frame布局控件(九)

    frame控件 frame控件是将窗口分成好几个小模块,然后每个小模块中添加控件. 也就是将窗口合理的布局 由于和其他控件的操作基本一致,就不做注释了 import tkinter wuya = tk ...

  7. 你不知道的JavaScript--Item6 var预解析与函数声明提升(hoist )

    1.var 变量预编译 JavaScript 的语法和 C .Java.C# 类似,统称为 C 类语法.有过 C 或 Java 编程经验的同学应该对"先声明.后使用"的规则很熟悉, ...

  8. 32.APP后端处理表情的一些技巧

    app应用中文字夹带表情是个很常见的现象.甚至一些40多岁的大叔级用户,也喜欢在自己的昵称中夹带表情,在产品运营后发现这个现象,彻底颠覆了我的世界观. 在后台处理表情的时间,我遇到过下面3个问题: 1 ...

  9. Android 源码解析 之 setContentView

    转载请标明出处:http://blog.csdn.net/lmj623565791/article/details/41894125,本文出自:[张鸿洋的博客] 大家在平时的开发中,对于setCont ...

  10. cluster.go

    package clientv3 import (     pb "github.com/coreos/etcd/etcdserver/etcdserverpb"     &quo ...