getDate方法的妙用(js判斷閏年)

heath_learning發表於2019-02-16

對於js中的Date物件,我們new Date()後做的最多的操作就是getTime()、getFullYear()、getMonth()、getSecond(),在實際開發中幾乎很少會用到getDate()這個方法,因為應用場景太少了。在工作中我們經常會需要判斷某個年份是否是閏年這個需求,以前我們都是使用一套公式算出來的,這個方法比較麻煩,並且公式還記不住。getDate()方法就是我們的福音,用它可以很方便的實現判斷閏年的需求!

1.1、getDate()方法的使用

new Date()方法可以傳遞3個引數,如:new Date(年,月,數字);

1、new Date()第三個引數為0或為負數

/* 28,表示獲取2018年2月份的最後一天,即獲取2018年2月份的倒數第一天。*/
new Date(2018,2,0); // 28
new Date(2018,2,-1); // 27
new Date(2018,2,-2); // 26
new Date(2018,4,0); // 30
new Date(2020,2,0); // 29

1.2、new Date()第三個引數為正數
當第三個引數為正數時表示獲取該數字在(月份+1)中的第幾天,如果數字大於(月份+1)的最大天數,則月份往下再加1,然後再進行計算。

/* 25,表示獲取2018年4月份25日在當月中的序號 */
new Date(2018,3,25); // 25
/* 1,因為4月份沒有31號,因此月份再加1,序號變為31-30(30為4月份最大天數),即獲取的是5月份1號在5月份中的序號 */
new Date(2108,3,31); // 1
new Date(2108,3,32); // 2

2、判斷年份是否是閏年

2.1、使用getDate()方法判斷年份是否為閏年

/* 當new Date()第三個引數為0時可以獲取2018年2月份的最後一天,如果2月份的最後一天是29,那麼該年就是閏年 */
var days = new Date(2018,2,0); // 28
if(days == 29){
    console.log("2018年是閏年");
}else{
    console.log("2018年不是閏年");
}

2.2、使用公式計算是否是閏年

var year = new Date().getFullYear();
if((year % 4 == 0 && year % 100 != 0) || (year % 400 == 0)){
    console.log(year + "年是閏年");
}else{
    console.log(year + "年不是閏年");
}

相關文章