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 parseInt与Number函数的区别
Jan 21 Javascript
jQuery Ajax 实例全解析
Apr 20 Javascript
使用JQUERY进行后台页面布局控制DIV实现左右式
Jan 07 Javascript
jQuery幻灯片特效代码分享--鼠标滑过按钮时切换(2)
Nov 18 Javascript
Vue.js实现一个自定义分页组件vue-paginaiton
Sep 05 Javascript
谈谈对JavaScript原生拖放的深入理解
Sep 20 Javascript
Javascript基础回顾之(二) js作用域
Jan 31 Javascript
BootStrap表单时间选择器详解
May 09 Javascript
Angular中管道操作符(|)的使用方法
Dec 15 Javascript
前后端如何实现登录token拦截校验详解
Sep 03 Javascript
如何使用less实现随机下雪动画详解
Jan 02 Javascript
小程序使用wxs解决wxml保留2位小数问题
Dec 13 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 expects parameter 1 to be resource, array given 错误
2011/03/23 PHP
PHP编码转换函数 自动转换字符集支持数组转换
2012/12/16 PHP
Smarty模板简单配置与使用方法示例
2016/05/23 PHP
php 多文件上传的实现实例
2016/10/23 PHP
php简单计算权重的方法示例【适合抽奖类应用】
2019/06/10 PHP
javascript的函数
2007/01/31 Javascript
用js代码和插件实现wordpress雪花飘落效果的四种方法
2014/12/15 Javascript
浅析Node.js的Stream模块中的Readable对象
2015/07/29 Javascript
jQuery实现悬浮在右上角的网页客服效果代码
2015/10/24 Javascript
Angularjs实现带查找筛选功能的select下拉框示例代码
2016/10/04 Javascript
详解nodejs 文本操作模块-fs模块(五)
2016/12/23 NodeJs
详解如何在NodeJS项目中优雅的使用ES6
2017/04/22 NodeJs
Angular.js中定时器循环的3种方法总结
2017/04/27 Javascript
javascript 跨域问题以及解决办法
2017/07/17 Javascript
微信小程序仿今日头条导航栏滚动解析
2019/08/20 Javascript
layer ui插件显示tips时,修改字体颜色的实现方法
2019/09/11 Javascript
webpack是如何实现模块化加载的方法
2019/11/06 Javascript
vue使用nprogress加载路由进度条的方法
2020/06/04 Javascript
python解析含有重复key的json方法
2019/01/22 Python
Python处理session的方法整理
2019/08/29 Python
ipad上运行python的方法步骤
2019/10/12 Python
Python如何实现FTP功能
2020/05/28 Python
Python pytesseract验证码识别库用法解析
2020/06/29 Python
python如何将图片转换素描画
2020/09/08 Python
用HTML5实现手机摇一摇的功能的教程
2012/10/30 HTML / CSS
eBay法国购物网站:eBay.fr
2017/10/21 全球购物
欧洲有机婴儿食品最大的市场:Organic Baby Food(供美国和加拿大)
2018/03/28 全球购物
英国最大的割草机购买网站:Just Lawnmowers
2019/11/02 全球购物
公司业务员岗位职责
2014/03/18 职场文书
大学生预备党员自我评价
2015/03/04 职场文书
关于运动会的宣传稿
2015/07/23 职场文书
python中的被动信息搜集
2021/04/29 Python
MySql开发之自动同步表结构
2021/05/28 MySQL
Windows下redis下载、redis安装及使用教程
2021/06/02 Redis
Python echarts实现数据可视化实例详解
2022/03/03 Python
Nginx禁止ip访问或非法域名访问
2022/04/07 Servers