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 相关文章推荐
JavaScript实现Sleep函数的代码
Mar 04 Javascript
一起来写段JS drag拖动代码
Dec 09 Javascript
IE8中动态创建script标签onload无效的解决方法
Dec 22 Javascript
以jQuery中$.Deferred对象为例讲解promise对象是如何处理异步问题
Nov 13 Javascript
推荐三款日期选择插件(My97DatePicker、jquery.datepicker、Mobiscroll)
Apr 21 jQuery
详解微信小程序获取当前时间及日期的方法
Apr 28 Javascript
JS解惑之Object中的key是有序的么
May 06 Javascript
超简单的微信小程序轮播图
Nov 22 Javascript
微信小程序返回上一页传参并刷新过程解析
Dec 13 Javascript
vue-cli设置css不生效的解决方法
Feb 07 Javascript
Vue快速实现通用表单验证的方法
Feb 24 Javascript
不依任何赖第三方,单纯用vue实现Tree 树形控件的案例
Sep 21 Javascript
一种基于浏览器的自动小票机打印实现方案(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
用php的ob_start来生成静态页面的方法分析
2011/03/09 PHP
Apache2中实现多网站域名绑定的实现方法
2011/06/01 PHP
PHP实现多图片上传类实例
2014/07/26 PHP
PHP实现简单实用的验证码类
2015/07/29 PHP
js截取固定长度的中英文字符的简单实例
2013/11/22 Javascript
改变状态栏文字的js代码
2014/06/13 Javascript
JavaScript中判断整字类型最简洁的实现方法
2014/11/08 Javascript
jQuery如何防止这种冒泡事件发生
2015/02/27 Javascript
jQuery中的siblings用法实例分析
2015/12/24 Javascript
弹出遮罩层后禁止滚动效果【实现代码】
2016/04/29 Javascript
js改变style样式和css样式的简单实例
2016/06/28 Javascript
AngularJs表单验证实例代码解析
2016/11/29 Javascript
JavaScript如何一次性展示几万条数据
2017/03/30 Javascript
Vue2.0实现购物车功能
2017/06/05 Javascript
vue中node_modules中第三方模块的修改使用详解
2019/05/31 Javascript
vue 解决uglifyjs-webpack-plugin打包出现报错的问题
2020/08/04 Javascript
Python continue语句用法实例
2014/03/11 Python
Python的Django框架中forms表单类的使用方法详解
2016/06/21 Python
python生成器,可迭代对象,迭代器区别和联系
2018/02/04 Python
Python实现对文件进行单词划分并去重排序操作示例
2018/07/10 Python
Python实现KNN(K-近邻)算法的示例代码
2019/03/05 Python
Python中的几种矩阵乘法(小结)
2019/07/10 Python
python操作gitlab API过程解析
2019/12/27 Python
pytorch1.0中torch.nn.Conv2d用法详解
2020/01/10 Python
python读取与处理netcdf数据方式
2020/02/14 Python
Python下载网易云歌单歌曲的示例代码
2020/08/12 Python
python基于opencv实现人脸识别
2021/01/04 Python
css3 border旋转时的动画应用
2016/01/22 HTML / CSS
HTML5 Web存储方式的localStorage和sessionStorage进行数据本地存储案例应用
2012/12/09 HTML / CSS
Probikekit日本:自行车套件,跑步和铁人三项装备
2017/04/03 全球购物
澳大利亚在线消费电子产品商店:TobyDeals
2020/01/05 全球购物
一份全面的PHP面试问题考卷
2012/07/15 面试题
毕业生幼师求职自荐信
2013/10/01 职场文书
兼职学生的自我评价
2013/11/24 职场文书
企业安全生产承诺书
2014/05/22 职场文书
幼儿园教学反思范文
2016/03/02 职场文书