jQuery实现日期联动效果实例


Posted in Javascript onJuly 26, 2016

本文实例讲述了jQuery实现日期联动效果的方法。分享给大家供大家参考,具体如下:

实现目标:

jQuery实现日期联动效果实例

两个日期,有下拉框:

<head>
//导入jquery地址
<script src="jquery-1.7.2.min.js" language="JavaScript" type="text/javascript"></script>
<script type="text/javascript">
//startYear发生变化
function changeYear(str,isstart)
{
  var pre = "start";
  if(isstart == false)
  {
    pre = "end";
  }
  var startMonth = $(pre + "Month").value;
  if(startMonth == "")
  {
    var e = $(pre + "Month");
    optionClear(e);
    return;
  }
  var n = MonHead[startMonth - 1];
  if(startMonth == 2 && IsPinYear($(pre + "Year").value))
  {
    n++;
  }
  writeDay(n,pre);
}
function changeMonth(str,isstart)
{
  var pre = "start";
  if(isstart == false)
  {
    pre = "end";
  }
  var year = $(pre + "Year").value;
  if(year == "")
  {
    var e = $(pre + "Day");
    optionClear(e);
    return;
  }
  var n = MonHead[str - 1];
  if(str == 2 && IsPinYear($(pre + "Year")))
  {
    n++;
  }
  writeDay(n,pre);
}
function dateStart()
{
  var defaultStartY = "2011";
  var defaultStartM = "1";
  var defaultStartD = "14";
  var defaultEndY = "2011";
  var defaultEndM = "2";
  var defaultEndD = "23";
  MonHead = [31,28,31,30,31,30,31,31,30,31,30,31];
  var prestr = new Array("start","end");
  for(var j=0; j<2; j++)
  {
    var pre = prestr[j];
    //start 年
    var y = new Date().getFullYear();
    if(pre == "start")
    {
      //start初始选中前第10天
      var i_index = 0;
      for(var i=(y-10); i<=y; i++)
      {
        $(pre+"Year").options.add(new Option(""+i+"",i));
        if(i == defaultStartY)
        {
          $(pre+"Year").options[i_index].selected = true;
        }
        i_index++;
      }
    }
    else
    {
      var i_index =0;
      for(var i=(y-5); i<=y+5; i++)
      {
        $(pre+"Year").options.add(new Option(""+i+"",i));
        if(i == defaultEndY)
        {
          $(pre+"Year").options[i_index].selected = true;
        }
        i_index++;
      }
    }
    //start月
    defaultM = (pre == "start" ? defaultStartM : defaultEndM)
    for(var i = 1; i < 13; i++)
    {
      $(pre + "Month").options.add(new Option(""+i+"",i));
      if(i == defaultM)
      {
        $(pre + "Month").options[i-1].selected = true;
      }
    }
    //start日
    var n = MonHead[$(pre + "Month").value];
    if(new Date().getMonth == 1 && IsPinYear($(pre + "Year").value))
    {
      n++;
    }
    defaultD = (pre == "start" ? defaultStartD : defaultEndD)
    writeDay(n,pre);
    $(pre + "Day").options[defaultD-1].selected = true;
  }
}
function writeDay(n,pre)
{
  var e = $(pre + "Day");
  optionClear(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 % 4 == 0));
}
function optionClear(e)
{
  for(var i=e.options.length; i>=0; i--)
  {
    e.remove(i);
  }
}
</script>
</head>
<body onload="dateStart()">
<p name="selectdate">
    从
    <select id="startYear" name="startYear" onchange="changeYear(this.value,true)">
    </select>
    年
    <select id="startMonth" name="startMonth" onchange="changeMonth(this.value,true)">
    </select>
    月
    <select id="startDay" name="startDay">
    </select>
    日
    到
    <select id="endYear" name="endYear" onchange="changeYear(this.value,false)">
    </select>
    年
    <select id="endMonth" name="endMonth" onchange="changeMonth(this.value,false)">
    </select>
    月
    <select id="endDay" name="endDay">
    </select>
    日
</p>
</body>

参考了一些代码,终于能实现了~~

希望本文所述对大家jQuery程序设计有所帮助。

Javascript 相关文章推荐
ECMAScript 5中的属性描述符详解
Mar 02 Javascript
javascript实现多栏闭合展开式广告位菜单效果实例
Aug 05 Javascript
JS实现淡蓝色简洁竖向Tab点击切换效果
Oct 06 Javascript
轻松搞定jQuery.noConflict()
Feb 15 Javascript
80%应聘者都不及格的JS面试题
Mar 21 Javascript
微信小程序使用video组件播放视频功能示例【附源码下载】
Dec 08 Javascript
实例讲解JavaScript截取字符串
Nov 30 Javascript
vue-cli3跨域配置的简单方法
Sep 06 Javascript
JS计算斐波拉切代码实例
Sep 12 Javascript
构建Vue大型应用的10个最佳实践(小结)
Nov 07 Javascript
解决React在安装antd之后出现的Can't resolve './locale'问题(推荐)
May 03 Javascript
Vue实现小购物车功能
Dec 21 Vue.js
一种基于浏览器的自动小票机打印实现方案(js版)
Jul 26 #Javascript
深入理解JavaScript函数参数(推荐)
Jul 26 #Javascript
JavaScript从0开始构思表情插件
Jul 26 #Javascript
只需五句话搞定JavaScript作用域(经典)
Jul 26 #Javascript
第一次接触神奇的Bootstrap基础排版
Jul 26 #Javascript
js获取html的span标签的值方法(超简单)
Jul 26 #Javascript
js无法获取到html标签的属性的解决方法
Jul 26 #Javascript
You might like
十大“创意”战术!
2020/03/04 星际争霸
PHP set_time_limit(0)长连接的实现分析
2010/03/02 PHP
windows服务器中检测PHP SSL是否开启以及开启SSL的方法
2014/04/25 PHP
php截取指定2个字符之间字符串的方法
2015/04/15 PHP
php判断邮箱地址是否存在的方法
2016/02/13 PHP
PHP PDOStatement::errorInfo讲解
2019/01/31 PHP
超级强大的表单验证
2006/06/26 Javascript
JavaScript实现关键字高亮功能
2014/11/12 Javascript
探讨JavaScript中的Rest参数和参数默认值
2015/07/29 Javascript
jQuery 3.0十大新特性最终版发布
2016/07/14 Javascript
elementUI 设置input的只读或禁用的方法
2018/10/30 Javascript
jQuery实现小火箭返回顶部特效
2020/02/03 jQuery
three.js 如何制作魔方
2020/07/31 Javascript
[06:13]DOTA2进化论(修改版)
2013/10/08 DOTA
[46:02]DOTA2上海特级锦标赛D组资格赛#2 Liquid VS VP第二局
2016/02/28 DOTA
[02:03]风行者至宝清风环佩外观展示
2020/09/05 DOTA
Python解析xml中dom元素的方法
2015/03/12 Python
Python字符串处理之count()方法的使用
2015/05/18 Python
Python3.5 处理文本txt,删除不需要的行方法
2018/12/10 Python
python程序快速缩进多行代码方法总结
2019/06/23 Python
ipython和python区别详解
2019/06/26 Python
关于Python3爬虫利器Appium的安装步骤
2020/07/29 Python
Python使用Pygame绘制时钟
2020/11/29 Python
Pandas DataFrame求差集的示例代码
2020/12/13 Python
HTML5的标签的代码的简单介绍 HTML5标签的简介
2012/05/28 HTML / CSS
详解移动端h5页面根据屏幕适配的四种方案
2020/04/15 HTML / CSS
如何用JQuery进行表单验证
2013/05/29 面试题
应聘教师推荐信
2013/10/31 职场文书
客服主管岗位职责
2013/12/13 职场文书
《老王》教学反思
2014/02/23 职场文书
赡养老人协议书
2014/04/21 职场文书
改作风抓落实促发展心得体会
2014/09/10 职场文书
中学生勤俭节约倡议书
2015/04/29 职场文书
2015年材料员工作总结
2015/04/30 职场文书
2015年公司国庆放假通知
2015/07/30 职场文书
详解Django中 render() 函数的使用方法
2021/04/22 Python