<HTML><HEAD>
<script type="text/javascript">

//目前只判断了4位有效输入的年份,
//日期输出格式已处理,统一为"yyyy-mm-dd"格式.
<!--
function checkInput(fieldValue,len){ //判断输入是否都为正确数据格式

if(fieldValue.length < 0 || fieldValue.length > len)
{
alert("数据长度不对,请重新填写.年份为四位,如:2006;周次为1-2位,如1或01");
return false;
}
else
{
for(var i = 0 ; i < fieldValue.length; i++ )
{
temp = fieldValue.substr(i,1)
if(isNaN(temp))
{
alert("非法数据输入!只能输入数字,请重新输入.");
return false;
}
}
var msg = false; //处理输入0/00时出现的问题.
for(var i = 0 ; i < fieldValue.length; i++ )
{

tmp = fieldValue.substr(i,1)
if(tmp != "0") { msg = true; }
}
}
if (msg == false) {alert("非法数据输入,数据不能全部为'0',请重新输入.");return false;}

}

function calcu(){
/*==================================================================================*/
//年份特殊判断,目前只实现4为有效数字输入,有空再考虑2位有效数字输入.
//4位可计算出1000--9999年间的任意时间,2位则暂时只计算1900-2099年(暂不设计)
if(document.form1.thisYear.value.length != 4)
{
alert("年份目前只能输入四位有效数字-_-! 请重新输入.");
document.form1.thisYear.focus();
return false;
}
/*==================================================================================*/
if(document.form1.thisYear.value.charAt(0) == "0")
{
alert("年份第一位不能为'0',请重新输入.");
document.form1.thisYear.focus();
return false;
}
//-------------------------------------------------------------------------------------
//判断年份输入是否合法.
if (checkInput(document.form1.thisYear.value,4) == false) { return false; }
//判断周次输入是否合法.
if (checkInput(document.form1.thisWeek.value,2) == false) { return false; }
//-------------------------------------------------------------------------------------

var yearStart = new Date(parseInt(document.form1.thisYear.value),0,1) //设置该年1.1.
var firstDay = yearStart.getDay(); //星期
var yearEnd = new Date(parseInt(document.form1.thisYear.value),11,31) //设置该年12.31.
var endDay = yearEnd.getDay(); //星期
//-------------------------------------------------------------------------------------
//判断输入是否超过最大周次.
var maxWeek; //该年最大周次.1.1.在周一到周四,则为该年第一周,否则为上年最后一周.
if((firstDay>=1&&firstDay<=4)&&(endDay==0||endDay==4||endDay==5||endDay==6))
{
maxWeek = 53; //1.1.和12.31.都在本年,则该年有53周,否则52周
}
else
{
maxWeek = 52;
}
if(parseInt(document.form1.thisWeek.value,10) > maxWeek)
{
alert(document.form1.thisYear.value + " 年只有 " + maxWeek + " 周,请重新填写周次.");
document.form1.thisWeek.focus();
return false;
}
//-------------------------------------------------------------------------------------

//-------------------------------------------------------------------------------------
//对1.1.所在周的前后几天特殊处理.
if(firstDay>=0&&firstDay<=4) {other = firstDay - 1;}
else {other = firstDay - 8}
//-------------------------------------------------------------------------------------

//-------------------------------------------------------------------------------------
//时间调整,得出要计算周的起/始时间.
//距离当年1.1.的总天数
days = (parseInt(document.form1.thisWeek.value,10)-1)*7 - other;
//转换成Ms.......
var oneMinute = 60 * 1000;
var oneHour = oneMinute * 60;
var oneDay = oneHour * 24;
//1.1.至1/1/70的毫秒数
var dateInMs = yearStart.getTime();
//当前所选周第一天离1/1/70的毫秒数.
dateInMs += oneDay * days
//日期调整(设置1/1/70至今的毫秒数)
yearStart.setTime(dateInMs);
//当前所选周最后一天处理,同上.
var weekEnd = new Date(parseInt(document.form1.thisYear.value),0,1)
var dateInMs1 = weekEnd.getTime ();
dateInMs1 += oneDay * (days + 6);
weekEnd.setTime(dateInMs1)
//-------------------------------------------------------------------------------------

//-------------------------------------------------------------------------------------
//月和日的处理,一位变两位,如:1->01.
var month = yearStart.getMonth() + 1
if(month<10) { month = "0" + month;}
var day = yearStart.getDate();
if(day<10) { day = "0" + day;}
var month1 = weekEnd.getMonth() + 1;
if(month1<10) { month1 = "0" + month1;}
var day1 = weekEnd.getDate();
if(day1<10) { day1 = "0" + day1;}
//-------------------------------------------------------------------------------------

//-------------------------------------------------------------------------------------
//赋值给text框显示.
document.form1.weekTime.value = yearStart.getFullYear() + "-" + month + "-" + day;
document.form1.weekend.value = weekEnd.getFullYear() + "-" + month1 + "-" + day1;
//-------------------------------------------------------------------------------------
}

//-->
</script>
</HEAD>
<BODY>
<form name = "form1">
<P>
<font size=2 color="blue">输入年份/周次,点"计算",程序将自动计算出该年该周次的时间段:</font><br><br>

<font size=2 color="red">年&nbsp;&nbsp;份:<input name = "thisYear" >&nbsp;&nbsp;//填写四位格式的年份,如:2006</font><br>
<font size=2 color="red">周&nbsp;&nbsp;次:<input name = "thisWeek" >&nbsp;&nbsp;//填写要计算的周次,如1或01</font><br>
<font size=2 color="red">时间段:<input name = "weekTime" >至<input name = "weekend" >&nbsp;&nbsp;//不需要填写,程序将自动计算</font><br><br>
<input type = "button" name = "btn" value = "计算" onclick = "calcu()">
<input type = "reset" name = "reset" value = "重置"> </P>
</form>
</BODY>
</HTML>

js 计算某年某周日期范围的更多相关文章

  1. JavaScript(JS)计算某年某月的天数(月末)

    方法1 /** * 获取某年月的天数 * @param year 年 * @param month 月(0-11) * @returns {number} 天数 */ var getDaysOfMon ...

  2. C#关于日期 月 天数 和一年有多少周及根据某年某周获取时间段的计算(转)

    /// 当前月有多少天 /// </summary> /// <param name="y"></param> /// <param na ...

  3. js计算2个日期相差的天数,两个日期相差的天数,日期相隔天数

    js计算2个日期相差的天数,两个日期相差的天数,日期相隔天数 >>>>>>>>>>>>>>>>>& ...

  4. JS计算两个日期时间之差之天数不正确

    做了一个时间倒计时,发现天数总是不正确. js代码: //定义目标日期 var targetTime = new Date(); //目标日期 targetTime.setFullYear(2015, ...

  5. js 计算快速统计中用到的日期

    前言 最近在做统计报表模块,其中查询条件用到了快速查询,主要为了方便客户统计查询常用的几个日期纬度,比如本周.上周.本月.上月.昨日. 使用js计算,主要用到了js Date. getDate().g ...

  6. js计算两个日期的天数差值

    js计算两个日期的天数差值 通过两个日期计算这两个日期之间的天数差值 /** * 计算天数差的函数,通用 * @param sDate1 * @param sDate2 * @returns {Num ...

  7. JS计算两个日期之间的天数

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  8. PHP计算每月几周,每周的开始结束日期

    PHP计算每月几周,每周的开始结束日期 因为项目中需要一个每周工作计算的功能,具体日期的算法是,把每月拆分成几个周,最后一个星期这个月份的天数不够就补上下个月的. 列如今天8月27星期一,这个月有31 ...

  9. Java获取某年某周的最后一天

    package test; import java.text.SimpleDateFormat; import java.util.Calendar; /** * ClassName: LastDay ...

随机推荐

  1. lib,dll区别 及 VS中如何添加lib,dll

    1.加载lib/头文件 分两种方法: (1)适用于当前项目 第一步:项目->属性->C/C++->常规->附加包含目录(浏览.h文件的路径) 添加包含文件 第二步:项目-> ...

  2. 14--物理引擎Box2D

    物理模拟引擎专注于模拟现实世界中物体以及物体之间的基本运动规律.在游戏中引入物理引擎能提高游戏的真实性和可玩性,如<愤怒的小鸟>中小鸟弹出的抛物线运动.<割绳子>中割后的运动等 ...

  3. python学习第七天 -- dict 和set

    今天主要学习关于python 的dict(全称dictionary)和set.dict的用法跟javascript 中map表类似,key + value结构语言.而set,准确来说,只是key的集合 ...

  4. XML DOM 遍历Xml文档

    1.xml文档内容: <?xml version="1.0" encoding="utf-8" ?> <bookstore> <b ...

  5. dll signing issue

    1. Verify if a dll has been signed sn.exe -v module.dll Scenario: sometimes for security reasons, a ...

  6. docker中运行ASP.NET Core Web API

    在docker中运行ASP.NET Core Web API应用程序 本文是一篇指导快速演练的文章,将介绍在docker中运行一个ASP.NET Core Web API应用程序的基本步骤,在介绍的过 ...

  7. Swift—属性观察者-备

    为了监听属性的变化,Swift提供了属性观察者.属性观察者能够监听存储属性的变化,即便变化前后的值相同,它们也能监听到. 属性观察者主要有以下两个: willSet:观察者在修改之前调用. didSe ...

  8. TestNG使用Eclipse建立Test Case - 就是爱Java

    除了JUnit可以进行单元测试外,还可以使用TestNG来撰写Test Case,这是另一种测试Framework,它是为更广泛的测试场合而设计,可以运行在没有修改过的JUnit测试,除非看到它们的i ...

  9. VIM下Express jade空格问题:expected "indent", but got "newline"

    Error: /home/y/my_note/nodejs/myapp/views/index.jade: | -list=[{name:,email:'zhangsan@123.com'}] | - ...

  10. Android 之 Window、WindowManager 与窗口管理

    其实在android中真正展示给用户的是window和view,activity在android中所其的作用主要是处理一些逻辑问题,比如生命周期的管理.建立窗口等.在android中,窗口的管理还是比 ...