JS getMonth()日期函数的值域是0-11
作者:
好久没用JS写代码了,结果在计算日期时,出现了一个问题,困扰了我半天。最后终于搞清了问题的根源。
我选择月份列表项后,获得年份值和月份值,计算获得当月1号日期值和当月最后一天的日期值。
正确代码如下:
<script language="javascript">
function selDate(y, m)
{
//输出当月1号字符串
document.form1.startDT.value=y+"-"+m+"-1";
//计算下个月的年份(y)、月份值(m)
if(m==12)
{
y++;
m=1;
}
else
{
m++;
}
//生成下个月1日的Date值
var dt=new Date(y, m-1, 1); //月份值0--11
//一天差值=86400000,将下月1日转换成数值,再相减,得上月最后一天Date值
var n=Date.parse(dt);
n -= 86400000;
var dt1=new Date(n);
//输出当月最后一天日期字符串
document.form1.stopDT.value=dt1.getYear()+"-"+(dt1.getMonth()+1)+"-"+dt1.getDate();
}
</script>
开始我将“var dt=new Date(y, m-1, 1);”写成了“var dt=new Date(y, m, 1);”。而最后一句“dt1.getMonth()”没有加1。结果可想而知,明明是“2010-2-28”,输出的却是“2010-1-28”,而“2010-1-31”输出却是“2010-0-31”。
刚开始感觉莫名其妙,多试了,就找到了错误规律,发现月份值域是“0-11”而不是“1-12”。
希望下次过段时间没用JS后,本文能提醒我。
正确代码如下:
复制代码 代码如下:
<script language="javascript">
function selDate(y, m)
{
//输出当月1号字符串
document.form1.startDT.value=y+"-"+m+"-1";
//计算下个月的年份(y)、月份值(m)
if(m==12)
{
y++;
m=1;
}
else
{
m++;
}
//生成下个月1日的Date值
var dt=new Date(y, m-1, 1); //月份值0--11
//一天差值=86400000,将下月1日转换成数值,再相减,得上月最后一天Date值
var n=Date.parse(dt);
n -= 86400000;
var dt1=new Date(n);
//输出当月最后一天日期字符串
document.form1.stopDT.value=dt1.getYear()+"-"+(dt1.getMonth()+1)+"-"+dt1.getDate();
}
</script>
开始我将“var dt=new Date(y, m-1, 1);”写成了“var dt=new Date(y, m, 1);”。而最后一句“dt1.getMonth()”没有加1。结果可想而知,明明是“2010-2-28”,输出的却是“2010-1-28”,而“2010-1-31”输出却是“2010-0-31”。
刚开始感觉莫名其妙,多试了,就找到了错误规律,发现月份值域是“0-11”而不是“1-12”。
希望下次过段时间没用JS后,本文能提醒我。
您可能感兴趣的文章:
- PHP笔记之:日期函数的使用介绍
- python中关于时间和日期函数的常用计算总结(time和datatime)
- SQL Server 日期函数CAST 和 CONVERT 以及在业务中的使用介绍
- PHP系列学习之日期函数使用介绍
- PHP中date()日期函数有关参数整理
- sql 查询本年、本月、本日记录的语句,附SQL日期函数
- PHP中Date()时间日期函数的使用方法小结
- mysql From_unixtime及UNIX_TIMESTAMP及DATE_FORMAT日期函数
- js 格式化时间日期函数小结
- javascript 格式化时间日期函数代码脚本之家修正版
- oracle 日期函数集合(集中版本)
- asp.net 日期函数 某月的第一天和最后一天的日期
- Oracle 函数大全[字符串函数,数学函数,日期函数]
- Oracle日期函数简介
- 深入mysql YEAR() MONTH() DAYOFMONTH()日期函数的详解