Javascript实现通过选择周数显示开始日和结束日的实现代码


Posted in Javascript onMay 30, 2016

 最近在一个项目中遇到一个查询页面,其中一个查询条件是根据选择的年份、月以及周数显示选择的该周从几号到几号,这样一个需求。在网上搜索了一下,有类似的但是没有完全一样的,只好自己动手。思路是首先取得所选择的该年月1号这一天是星期几,然后算出这一周中周一的日期。

以此为基点,第1周的结束日即为这一天加6,第2周的开始日为这一天加7,结束日为这一天加13,以此类推,直到推算出第5周的开始日和结束日。

具体代码如下:

//该方法有两个参数,date是给定的日期型参数,days是需要在该日期进行加减的天数。 
//例如,add(2010-10-01,-3)返回从2010-10-01这一天往前退3天的日期即2010-09-28 
function addDate(date,days){ 
var d=new Date(date); 
d.setDate(d.getDate()+days); 
var m=d.getMonth()+1; 
var tmpDate = d.getFullYear()+ "/" + m + "/" + d.getDate(); 
var resultDate = new Date(tmpDate); 
return resultDate; 
} 
//对选择的年月转换为YYYY-MM-dd的格式 
function changeDateFormat(DateIn){ 
var year = 0; 
var month = 0; 
var Day = 0; 
var currentDate = ""; 
year = DateIn.getYear(); 
month = DateIn.getMonth() + 1; 
Day = DateIn.getDate(); 
currentDate = year + "-"; 
if(month > 10){ 
currentDate = currentDate + month + "-"; 
}else{ 
currentDate = currentDate + "0" + month + "-"; 
} 
if(Day > 10){ 
currentDate = currentDate + Day; 
}else{ 
currentDate = currentDate + "0" + Day; 
} 
return currentDate; 
} 
//根据选择的周计算出本周的开始日和结束日 
function weekToDate(weekNumber,strWeekDay,dateIn){ 
//输出的开始日 var outputDate_1 = ""; 
//输出的结束日 var outputDate_2 = ""; 
var tmp_date= ""; 
//如果选择的年月1号这一天恰好为sunday,该周monday的日期为这一天的日期-6 
if(strWeekDay == '0'){ 
outputDate_1 = addDate(dateIn,-6); 
} 
//如果选择的年月1号这一天为monday,第二个参数设为0,以下以此类推。 
if(strWeekDay == '1'){ 
outputDate_1 = addDate(dateIn,0); 
} 
if(strWeekDay == '2'){ 
outputDate_1 = addDate(dateIn,-1); 
} 
if(strWeekDay == '3'){ 
outputDate_1 = addDate(dateIn,-2); 
} 
if(strWeekDay == '4'){ 
outputDate_1 = addDate(dateIn,-3); 
} 
if(strWeekDay == '5'){ 
outputDate_1 = addDate(dateIn,-4); 
} 
if(strWeekDay == '6'){ 
outputDate_1 = addDate(dateIn,-5); 
} 
if(weekNumber == '1'){ 
outputDate_2 = dateIn; 
} 
if(weekNumber == '2'){ 
outputDate_2 = addDate(outputDate_1,+7); 
} 
if(weekNumber == '3'){ 
outputDate_2 = addDate(outputDate_1,+14); 
} 
if(weekNumber == '4'){ 
outputDate_2 = addDate(outputDate_1,+21); 
} 
if(weekNumber == '5'){ 
outputDate_2 = addDate(outputDate_1,+28); 
} 
if(weekNumber == '1'){ 
//第1周的开始日结束日计算基点都是outputDate_1,因此单独判断 
document.getElementById("spnDate").value = changeDateFormat(outputDate_1); 
temp_date = addDate(outputDate_1,+6); 
document.getElementById("finishTime").value =changeDateFormat(temp_date); 
}else{ 
//第2周以后的开始日结束日都以outputDate_2为计算基点 
document.getElementById("spnDate").value = changeDateFormat(outputDate_2); 
temp_date = addDate(outputDate_2,+6); 
document.getElementById("finishTime").value =changeDateFormat(temp_date); 
} 
} 
function getFromToDateOfSelectedWeek(){ 
var year = document.getElementById("sltYear"); 
var optionYear=year.getElementsByTagName("option"); 
var strYear = "" ; 
for(var i=0;i<optionYear.length;++i) 
{ 
if(optionYear[i].selected){ 
strYear = optionYear[i].text; 
} 
} 
var month = document.getElementById("sltMonth"); 
var option = month.getElementsByTagName("option"); 
var strMonth = "" ; 
for(var i=0;i<option.length;++i) 
{ 
if(option[i].selected){ 
strMonth = option[i].text; 
} 
} 
//根据选择的年月,组合成yyyy/mm/01的日期字符串 
var sltDate_tmp_0 = strYear+ "/" + strMonth + "/" + "1"; 
//将日期字符串转换为日期型 
var sltDate_tmp_1 = new Date(sltDate_tmp_0); 
//取得该月1号所在的星期数 
var weekDay = sltDate_tmp_1.getDay(); 
//获取页面选择的周数 
var weekNumber = document.getElementById("weekNumber"); 
var optionWeek=weekNumber.getElementsByTagName("option"); 
var strWeek = "" ; 
var tmp_date= ""; 
var outputDate_1 = ""; 
var outputDate_2 = ""; 
for(var i=0;i<optionWeek.length;++i) 
{ 
if(optionWeek[i].selected){ 
strWeek = optionWeek[i].text; 
} 
} 
//选择第1周时计算该年月1号这一天为monday到sunday各种可能性,返回该周monday到sunday的日期 
//以下判断以此类推 
if(strWeek == '1'){ 
if(weekDay == '0'){ 
weekToDate(strWeek,'0',sltDate_tmp_1); 
} 
if(weekDay == '1'){ 
weekToDate(strWeek,'1',sltDate_tmp_1); 
} 
if(weekDay == '2'){ 
weekToDate(strWeek,'2',sltDate_tmp_1); 
} 
if(weekDay == '3'){ 
weekToDate(strWeek,'3',sltDate_tmp_1); 
} 
if(weekDay == '4'){ 
weekToDate(strWeek,'4',sltDate_tmp_1); 
} 
if(weekDay == '5'){ 
weekToDate(strWeek,'5',sltDate_tmp_1); 
} 
if(weekDay == '6'){ 
weekToDate(strWeek,'6',sltDate_tmp_1); 
} 
} 
if(strWeek == '2'){ 
if(weekDay == '0'){ 
weekToDate(strWeek,'0',sltDate_tmp_1); 
} 
if(weekDay == '1'){ 
weekToDate(strWeek,'1',sltDate_tmp_1); 
} 
if(weekDay == '2'){ 
weekToDate(strWeek,'2',sltDate_tmp_1); 
} 
if(weekDay == '3'){ 
weekToDate(strWeek,'3',sltDate_tmp_1); 
} 
if(weekDay == '4'){ 
weekToDate(strWeek,'4',sltDate_tmp_1); 
} 
if(weekDay == '5'){ 
weekToDate(strWeek,'5',sltDate_tmp_1); 
} 
if(weekDay == '6'){ 
weekToDate(strWeek,'6',sltDate_tmp_1); 
} 
} 
if(strWeek == '3'){ 
if(weekDay == '0'){ 
weekToDate(strWeek,'0',sltDate_tmp_1); 
} 
if(weekDay == '1'){ 
weekToDate(strWeek,'1',sltDate_tmp_1); 
} 
if(weekDay == '2'){ 
weekToDate(strWeek,'2',sltDate_tmp_1); 
} 
if(weekDay == '3'){ 
weekToDate(strWeek,'3',sltDate_tmp_1); 
} 
if(weekDay == '4'){ 
weekToDate(strWeek,'4',sltDate_tmp_1); 
} 
if(weekDay == '5'){ 
weekToDate(strWeek,'5',sltDate_tmp_1); 
} 
if(weekDay == '6'){ 
weekToDate(strWeek,'6',sltDate_tmp_1); 
} 
} 
if(strWeek == '4'){ 
if(weekDay == '0'){ 
weekToDate(strWeek,'0',sltDate_tmp_1); 
} 
if(weekDay == '1'){ 
weekToDate(strWeek,'1',sltDate_tmp_1); 
} 
if(weekDay == '2'){ 
weekToDate(strWeek,'2',sltDate_tmp_1); 
} 
if(weekDay == '3'){ 
weekToDate(strWeek,'3',sltDate_tmp_1); 
} 
if(weekDay == '4'){ 
weekToDate(strWeek,'4',sltDate_tmp_1); 
} 
if(weekDay == '5'){ 
weekToDate(strWeek,'5',sltDate_tmp_1); 
} 
if(weekDay == '6'){ 
weekToDate(strWeek,'6',sltDate_tmp_1); 
} 
} 
if(strWeek == '5'){ 
if(weekDay == '0'){ 
weekToDate(strWeek,'0',sltDate_tmp_1); 
} 
if(weekDay == '1'){ 
weekToDate(strWeek,'1',sltDate_tmp_1); 
} 
if(weekDay == '2'){ 
weekToDate(strWeek,'2',sltDate_tmp_1); 
} 
if(weekDay == '3'){ 
weekToDate(strWeek,'3',sltDate_tmp_1); 
} 
if(weekDay == '4'){ 
weekToDate(strWeek,'4',sltDate_tmp_1); 
} 
if(weekDay == '5'){ 
weekToDate(strWeek,'5',sltDate_tmp_1); 
} 
if(weekDay == '6'){ 
weekToDate(strWeek,'6',sltDate_tmp_1); 
} 
} 
}

经过测试有一个bug,当2月1日是星期一并且选择的年份是平年时,选择2月的第5周,此时第5周的开始日已经是3月而不是2月了。例如,选择2010年2月第5周此时,程序会显示2010-03-1至2010-03-07。

解决方法有两种,一是当用户选择第5周时把月份下拉框强制设定到3月。二是,将周下拉框强制设定到第4周上,并且显示2010-02-22至2010年02-28。

经过测试有一个bug,当2月1日是星期一并且选择的年份是平年时,选择2月的第5周,此时第5周的开始日已经是3月而不是2月了。

例如,选择2010年2月第5周此时,程序会显示2010-03-1至2010-03-07。

解决方法有两种,一是当用户选择第5周时把月份下拉框强制设定到3月。二是,将周下拉框强制设定到第4周上,并且显示2010-02-22至2010年02-28。

经过测试有一个bug,当2月1日是星期一并且选择的年份是平年时,选择2月的第5周,此时第5周的开始日已经是3月而不是2月了。

例如,选择2010年2月第5周此时,程序会显示2010-03-1至2010-03-07。

解决方法有两种,一是当用户选择第5周时把月份下拉框强制设定到3月。二是,将周下拉框强制设定到第4周上,并且显示2010-02-22至2010年02-28。

以上所述是小编给大家介绍的基于Javascript实现通过选择周数显示开始日和结束日的实现代码,希望对大家有所帮助!

Javascript 相关文章推荐
Javascript学习笔记之 对象篇(四) : for in 循环
Jun 24 Javascript
node.js中的fs.chownSync方法使用说明
Dec 16 Javascript
jQuery插件Skippr实现焦点图幻灯片特效
Apr 12 Javascript
JavaScript将字符串转换为整数的方法
Apr 14 Javascript
jquery使用ul模拟select实现表单美化的方法
Aug 18 Javascript
jQuery随手笔记之常用的jQuery操作DOM事件
Nov 29 Javascript
JavaScript截取、切割字符串的技巧
Jan 07 Javascript
最简单的tab切换实例代码
May 13 Javascript
jQuery实现常见的隐藏与展示列表效果示例
Jun 04 jQuery
vue+Element-ui实现分页效果实例代码详解
Dec 10 Javascript
基于jquery实现的tab选项卡功能示例【附源码下载】
Jun 10 jQuery
一文读懂vue动态属性数据绑定(v-bind指令)
Jul 20 Javascript
JS组件Bootstrap Table使用实例分享
May 30 #Javascript
Bootstrap table分页问题汇总
May 30 #Javascript
浅析Javascript中bind()方法的使用与实现
May 30 #Javascript
Bootstrap Paginator分页插件使用方法详解
May 30 #Javascript
深入理解JavaScript中的call、apply、bind方法的区别
May 30 #Javascript
全面解析Bootstrap中transition、affix的使用方法
May 30 #Javascript
全面解析Bootstrap中form、navbar的使用方法
May 30 #Javascript
You might like
windows服务器中检测PHP SSL是否开启以及开启SSL的方法
2014/04/25 PHP
PHP之正则表达式捕获组与非捕获组(详解)
2015/07/29 PHP
PHP模拟asp中response类实现方法
2015/08/08 PHP
Alliance vs AM BO3 第二场2.13
2021/03/10 DOTA
javascript编程起步(第四课)
2007/01/10 Javascript
非常强大的 jQuery.AsyncBox 弹出对话框插件
2011/08/29 Javascript
js动态添加删除,后台取数据(示例代码)
2013/11/25 Javascript
Android中的jQuery:AQuery简介
2014/05/06 Javascript
深入理解JavaScript系列(31):设计模式之代理模式详解
2015/03/03 Javascript
自定义Angular指令与jQuery实现的Bootstrap风格数据双向绑定的单选与多选下拉框
2015/12/12 Javascript
JavaScript实现简单的tab选项卡切换
2016/01/05 Javascript
jquery 属性选择器(匹配具有指定属性的元素)
2016/09/06 Javascript
详谈for循环里面的break和continue语句
2017/07/20 Javascript
js将键值对字符串转为json字符串的方法
2018/03/30 Javascript
原生JS实现的自动轮播图功能详解
2018/12/28 Javascript
vue项目部署到nginx/tomcat服务器的实现
2019/08/26 Javascript
解决vue中使用less/sass及使用中遇到无效的问题
2020/10/24 Javascript
[03:02]生活中的Dendi之野外度假篇
2016/08/09 DOTA
在Mac OS系统上安装Python的Pillow库的教程
2015/11/20 Python
Python中 传递值 和 传递引用 的区别解析
2018/02/22 Python
python3对拉勾数据进行可视化分析的方法详解
2019/04/03 Python
Python当中的array数组对象实例详解
2019/06/12 Python
HTML5文档结构标签
2017/04/21 HTML / CSS
html5 Canvas画图教程(8)—canvas里画曲线之bezierCurveTo方法
2013/01/09 HTML / CSS
前端实现弹幕效果的方法总结(包含css3和canvas的实现方式)
2018/07/12 HTML / CSS
超市营业员求职简历的自我评价
2013/10/17 职场文书
领导的自我鉴定
2013/12/28 职场文书
市政工程技术专业自荐书
2014/07/06 职场文书
2015年度党员自我评价范文
2015/03/03 职场文书
工厂采购员岗位职责
2015/04/07 职场文书
工程质检员岗位职责
2015/04/08 职场文书
2015年教师业务工作总结
2015/05/26 职场文书
新闻通讯稿模板
2015/07/22 职场文书
如何利用STAR法则制作留学文书?
2019/08/26 职场文书
MySQL图形化管理工具Navicat安装步骤
2021/12/04 MySQL
Redis特殊数据类型HyperLogLog基数统计算法讲解
2022/06/01 Redis