JS getMonth()日期函數(shù)的值域是0-11
更新時間:2010年02月15日 13:12:26 作者:
好久沒用JS寫代碼了,結(jié)果在計算日期時,出現(xiàn)了一個問題,困擾了我半天。最后終于搞清了問題的根源。
我選擇月份列表項后,獲得年份值和月份值,計算獲得當月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日轉(zhuǎn)換成數(shù)值,再相減,得上月最后一天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。結(jié)果可想而知,明明是“2010-2-28”,輸出的卻是“2010-1-28”,而“2010-1-31”輸出卻是“2010-0-31”。
剛開始感覺莫名其妙,多試了,就找到了錯誤規(guī)律,發(fā)現(xiàn)月份值域是“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日轉(zhuǎn)換成數(shù)值,再相減,得上月最后一天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。結(jié)果可想而知,明明是“2010-2-28”,輸出的卻是“2010-1-28”,而“2010-1-31”輸出卻是“2010-0-31”。
剛開始感覺莫名其妙,多試了,就找到了錯誤規(guī)律,發(fā)現(xiàn)月份值域是“0-11”而不是“1-12”。
希望下次過段時間沒用JS后,本文能提醒我。
您可能感興趣的文章:
- PHP筆記之:日期函數(shù)的使用介紹
- python中關(guān)于時間和日期函數(shù)的常用計算總結(jié)(time和datatime)
- SQL Server 日期函數(shù)CAST 和 CONVERT 以及在業(yè)務(wù)中的使用介紹
- PHP系列學習之日期函數(shù)使用介紹
- PHP中date()日期函數(shù)有關(guān)參數(shù)整理
- sql 查詢本年、本月、本日記錄的語句,附SQL日期函數(shù)
- PHP中Date()時間日期函數(shù)的使用方法小結(jié)
- mysql From_unixtime及UNIX_TIMESTAMP及DATE_FORMAT日期函數(shù)
- js 格式化時間日期函數(shù)小結(jié)
- javascript 格式化時間日期函數(shù)代碼腳本之家修正版
- oracle 日期函數(shù)集合(集中版本)
- asp.net 日期函數(shù) 某月的第一天和最后一天的日期
- Oracle 函數(shù)大全[字符串函數(shù),數(shù)學函數(shù),日期函數(shù)]
- Oracle日期函數(shù)簡介
- 深入mysql YEAR() MONTH() DAYOFMONTH()日期函數(shù)的詳解
相關(guān)文章
IE與Firefox下javascript getyear年份的兼容性寫法
IE與Firefox下javascript getyear年份導致日期不統(tǒng)一的解決方法2007-12-12javascript 日期時間函數(shù)(經(jīng)典+完善+實用)
日期時間腳本庫方法列表2009-05-05