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面向对象编程
Mar 18 Javascript
分享一个我自己写的ToolTip提示插件(附源码)
Jan 20 Javascript
如何通过javascript操作web控件的自定义属性
Nov 25 Javascript
介绍JavaScript中Math.abs()方法的使用
Jun 14 Javascript
Javascript页面跳转常见实现方式汇总
Nov 28 Javascript
gameboy网页闯关游戏(riddle webgame)--仿微信聊天的前端页面设计和难点
Feb 21 Javascript
JS仿百度自动下拉框模糊匹配提示
Jul 25 Javascript
最实用的jQuery分页插件
Oct 09 Javascript
layui文件上传实现代码
May 20 Javascript
详解基于vue-cli3.0如何构建功能完善的前端架子
Oct 09 Javascript
微信小程序使用前置摄像头拍照
Oct 22 Javascript
手写Vue源码之数据劫持示例详解
Jan 04 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/02 日漫
仅Firefox中链接A无法实现模拟点击以触发其默认行为
2011/07/31 Javascript
Knockout text绑定DOM的使用方法
2013/11/15 Javascript
JS仿百度搜索自动提示框匹配查询功能
2013/11/21 Javascript
js中call与apply的用法小结
2013/12/28 Javascript
html的DOM中document对象images集合用法实例
2015/01/21 Javascript
jQuery实现首页顶部可伸缩广告特效代码
2015/04/15 Javascript
jQuery替换textarea中换行的方法
2015/06/10 Javascript
JavaScript如何实现组合列表框中元素移动效果
2016/03/01 Javascript
浅析javascript异步执行函数导致的变量变化问题解决思路
2016/05/13 Javascript
详解nodejs与javascript中的aes加密
2016/05/22 NodeJs
JavaScript中setter和getter方法介绍
2016/07/11 Javascript
JS图片等比例缩放方法完整示例
2016/08/03 Javascript
jQuery EasyUi 验证功能实例解析
2017/01/06 Javascript
JavaWeb表单及时验证功能在输入后立即验证(含用户类型,性别,爱好...的验证)
2017/06/09 Javascript
angular4实现tab栏切换的方法示例
2017/10/21 Javascript
VueJs里利用CryptoJs实现加密及解密的方法示例
2019/04/29 Javascript
highcharts.js数据绑定方式代码实例
2019/11/13 Javascript
浅谈Vue 自动化部署打包上线
2020/06/14 Javascript
浅谈Vue使用Elementui修改默认的最快方法
2020/12/05 Vue.js
Django中的Signal代码详解
2018/02/05 Python
Python引用计数操作示例
2018/08/23 Python
对python:循环定义多个变量的实例详解
2019/01/20 Python
python 获取sqlite3数据库的表名和表字段名的实例
2019/07/17 Python
python3 tcp的粘包现象和解决办法解析
2019/12/09 Python
用CSS3来实现社交分享按钮
2014/11/11 HTML / CSS
馥蕾诗美国官网:Fresh美国
2019/10/09 全球购物
Java面试题:说出如下代码的执行结果
2015/10/30 面试题
英语自荐信范文
2013/12/11 职场文书
超市采购员岗位职责
2014/02/01 职场文书
学生会竞聘书范文
2014/03/31 职场文书
乡镇遵守党的政治纪律情况对照检查材料
2014/09/26 职场文书
详解mysql三值逻辑与NULL
2021/05/19 MySQL
MySQL 聚合函数排序
2021/07/16 MySQL
Java实现二分搜索树的示例代码
2022/03/17 Java/Android
NoSQL优缺点与MongoDB数据库简介
2022/06/05 MongoDB