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 相关文章推荐
js不能跳转到上一页面的问题解决方法
Mar 01 Javascript
在JavaScript中typeof的用途介绍
Apr 11 Javascript
js控制页面控件隐藏显示的两种方法介绍
Oct 09 Javascript
javascript遇到html5的一些表单属性
Jul 05 Javascript
js实现滚动条滚动到页面底部继续加载
Dec 19 Javascript
jQuery 判断是否包含在数组中Array[]的方法
Aug 03 Javascript
jQuery实现的选择商品飞入文本框动画效果完整实例
Aug 10 Javascript
jQuery post数据至ashx实例详解
Nov 18 Javascript
JS异步文件分片断点上传的实现思路
Dec 25 Javascript
基于Bootstrap框架实现图片切换
Mar 10 Javascript
关于前后端json数据的发送与接收详解
Jul 30 Javascript
vue 获取url里参数的两种方法小结
Nov 12 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
PHP Streams(流)详细介绍及使用
2015/05/12 PHP
php判断邮箱地址是否存在的方法
2016/02/13 PHP
jquery实用代码片段集合
2010/08/12 Javascript
javascript ready和load事件的区别示例介绍
2013/08/30 Javascript
使用js在页面中绘制表格核心代码
2013/09/16 Javascript
JQuery实现表格动态增加行并对新行添加事件
2014/07/30 Javascript
加载列表时jquery获取ul中第一个li的属性
2014/11/02 Javascript
angularJS 中$attrs方法使用指南
2015/02/09 Javascript
jquery简单的弹出层浮动层代码
2015/04/27 Javascript
jQuery往textarea中光标所在位置插入文本的方法
2015/06/26 Javascript
JavaScript调用客户端Java程序的方法
2015/07/27 Javascript
Angular2  NgModule 模块详解
2016/10/19 Javascript
JavaScript正则替换HTML标签功能示例
2017/03/02 Javascript
python实现迭代法求方程组的根过程解析
2019/11/25 Javascript
原生js实现贪吃蛇游戏
2020/10/26 Javascript
[01:31]完美与DOTA2历程
2014/07/31 DOTA
[43:51]2018DOTA2亚洲邀请赛3月30日 小组赛B组 EG VS Secret
2018/03/31 DOTA
Python实现合并字典的方法
2015/07/07 Python
Python使用turtule画五角星的方法
2015/07/09 Python
tensorflow学习笔记之简单的神经网络训练和测试
2018/04/15 Python
python读写LMDB文件的方法
2018/07/02 Python
Python学习笔记之迭代器和生成器用法实例详解
2019/08/08 Python
Django异步任务线程池实现原理
2019/12/17 Python
keras tensorflow 实现在python下多进程运行
2020/02/06 Python
python实现贪吃蛇双人大战
2020/04/18 Python
韩国家庭购物网上商店:Nsmall
2017/05/07 全球购物
美丽乡村建设实施方案
2014/03/23 职场文书
外联部演讲稿
2014/05/24 职场文书
俞敏洪一分钟演讲稿
2014/08/26 职场文书
2014年外联部工作总结
2014/11/17 职场文书
银行实习推荐信
2015/03/27 职场文书
nginx配置ssl实现https的方法示例
2021/03/31 Servers
4种非常实用的python内置数据结构
2021/04/28 Python
pytorch 两个GPU同时训练的解决方案
2021/06/01 Python
Kubernetes部署实例并配置Deployment、网络映射、副本集
2022/04/01 Servers
MySQL数据库中的锁、解锁以及删除事务
2022/05/06 MySQL