天天看點

JavaScript生成指定範圍的時間清單

 遇到一個場景,需要拿到指定時間範圍内的每一天,滿足格式"YYYYMMDD",簡單的功能,簡單的思路

準備

 date對象有很多的方法,用到了以下:

 new date ()生成date對象,可以直接指定年月日等,new date(year,month,day)

 getFullYear() 傳回date對象中的年份

 getMonth() 傳回date對象中的月份(0~11),注意從0開始計

 getDate() 傳回date對象中的天,注意從 1 開始計

    getTime() 傳回1970年1月1日到date對象的毫秒數

解析指定範圍

 規定按照 yyyy-mm-dd格式字元串輸入時間範圍,split分割即可得到開始和結束時間的年月日,再生成對應的date對象,拿到毫秒數

var st = start.split('-');
  var et = end.split('-');
  var startTime = new Date(st[0],st[1]-1,st[2]).getTime();
  var endTime = new Date(et[0],et[1]-1,et[2]).getTime();
           

  注意 : 月份需要減 1 ,因為是從0開始計的

拿到每一天

  如何知道時間範圍内有那些天呢?上面有了開始和結束時間距離1970.1.1的毫秒數,每一天有24 * 60 * 60 * 1000的毫秒數,是以我們可以通過毫秒數計算出每一天

for( var i = startTime ; i <= endTime ; ){
        res.push(formatTime(i,'-'));
        i += 24 * 60 * 60 * 1000;
    }
           

格式化輸出

  将時間格式化,個位數字補0,加上指定的分割符

function formatTime(time,spliter){
    var date = new Date(time);
    var year = date.getFullYear();
    var month = (date.getMonth() + 1) >= 10 ? (date.getMonth() + 1) : '0' +  (date.getMonth() + 1);
    var day = date.getDate() >= 10 ? date.getDate() : '0' + date.getDate();
    
            var str = "";
        var week = new Date().getDay();
        if (week == 0) {
            str = "星期日";
        } else if (week == 1) {
            str = "星期一";
        } else if (week == 2) {
            str = "星期二";
        } else if (week == 3) {
            str = "星期三";
        } else if (week == 4) {
            str = "星期四";
        } else if (week == 5) {
            str = "星期五";
        } else if (week == 6) {
            str = "星期六";
        }  
        return {date:year+spliter+month+spliter+day,week:str}
}
           

驗證

JavaScript生成指定範圍的時間清單

繼續閱讀