JS getMonth()日期函数的值域是0-11

2019-12-24,,,

我选择月份列表项后,获得年份值和月份值,计算获得当月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后,本文能提醒我。

您可能感兴趣的文章:

  • 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()日期函数的详解

《JS getMonth()日期函数的值域是0-11.doc》

下载本文的Word格式文档,以方便收藏与打印。