JS日期计算

一、工具函数

// 补0函数,1补成01
function padding(num) {
    return num < 10 ? '0' + num : num
}
// 将日期格式化为2019/03/19
function formalDate(year, month, day) {
    return [year, padding(month), padding(day)].join('-')
}
// 日期格式化
function formalDate1(t) {
    var d = new Date(t);
    return [d.getFullYear(), padding(d.getMonth() + 1), padding(d.getDate())].join('-');
}

二、日期计算

1)根据给定年份计算周时间段列表:
function countWeekList(year) {
     var firstDay = new Date(year, 0, 1) // 获取给定年份第一天的日期
     while (firstDay.getDay() != 1) { // 获取给定年份第一个完整周的周一日期
        firstDay.setDate(firstDay.getDate() + 1)
     }
     // 获取给定年份下一年的第一天的日期,用来计算给定年份最后一天的日期,省去计算平闰年的步骤
     var lastDay = new Date(year + 1, 0, 1)
     var i = 1  // 控制输出
     var toDate, fromDate
     for (var from = firstDay; from < lastDay;) { 
         // 记录第i个周一的日期
         fromDate = formalDate(year, from.getMonth() + 1, from.getDate())
         from.setDate(from.getDate() + 6) // +6获取第i个周天的日期
         if (from < lastDay) { // 日期未超过下一年的第一天时
              toDate = formalDate(year, from.getMonth() + 1, from.getDate())
              from.setDate(from.getDate() + 1)
         } else { // 日期超过下一年的第一天时
              lastDay.setDate(lastDay.getDate() - 1) // 只截取当前年份的日期,超出的部分不要
              toDate = formalDate(year, lastDay.getMonth() + 1, lastDay.getDate())
         }
         // 打印结果
         if (fromDate < toDate) document.write(year + '年第' + i + '周:' + fromDate + '至' + toDate + '<br / >')
            i++
     }
}
console.log(countWeekList(2018))
2)根据给定年份计算月时间段列表:
function countMonthList(year) {
     var monthList = {} // 保存月份时间段列表
     var beginDate = new Date(year, 0, 1) // 保存当前年份第一天的日期
     var endDate = new Date(year + 1, 0, 1) // 保存当前年份下一年第一天的日期
     // 根据endDate获取一个完整月的时间段
     function getLast(et) {
         // 减去一天即为上月最后一天;
         et = et - 1000 * 60 * 60 * 24
         // 计算上月第一天的日期
         var t = new Date(et)
         t.setDate(1)
         st = t
         return {
              st: formalDate1(st),
              et: formalDate1(et)
         };
      }
      var i = 12
      while (i > 0) {
          monthList[i] = getLast(endDate)
          // 更新endDate的值
          endDate = new Date(monthList[i].st)
          i--
      }
      return monthList
}
console.log(countMonthList(2019))
3)根据给定年份计算当前年份的周数:
function countWeekNum(year) {
    var total = (year % 4 || year % 100) ? 365 : 366 // 计算当前年份的总天数
    var first = (new Date(year, 0, 1, 0)).getDay() // 获取当前年份第一天是周几
    var last = (new Date(year, 11, 31, 23)).getDay() // 计算当前年份最后一天是周几
    first = first === 0 ? 7 : first // getDay()返回日期为0~7,需重置以便后续计算
    // 如果最后一天是周日,只需减去first的相关值
    // 默认从当前年份的第一个周一开始计算,例如2019年1月1日是周二,总天数total需减去6
    if (last === 0) {
         return parseInt((total - (8 - first)) / 7)
    } else { 
         // 如果最后一天不是周日,总天数total需同时减去first和last的相关值,并在结果中加1
         // 2019年最后一周为2019-12-30-2020-12-31
         return parseInt((total - (8 - first) - last) / 7 + 1)
    }
 }
 console.log(countWeekNum2(2019)) // 52
4)根据当前日期计算当前月份的时间段:
// 根据当前日期计算当前月份的时间段:2019-02-01~2019-02-28
function countDayNum() {
    var curDate = new Date() // 获取当前日期
    // 获取当前月份最后一天的日期,setDate(0):设置为上个月最后一天
    var last = new Date(curDate.setMonth(curDate.getMonth() + 1))
    var last = new Date(curDate.setDate(0))
    var dayNum = last.getDate() // 获取当前月份的总天数
    var first = new Date(last.getFullYear(), last.getMonth(), 1) // 获取当前月份第一天的日期
    return [parseToPhpDate(first), parseToPhpDate(last), dayNum]
}
console.log(countDayNum2())
5)根据当前日期计算当前周的时间段:
// 根据当前日期计算当前周的时间段
// new Date(2019,1,29) === new Date(2019,2,1)
function countDayNum2() {
    var curDate = new Date()
    var day = curDate.getDay() === 0 ? 7 : curDate.getDay()
    var mondayTime = new Date(curDate.setDate(curDate.getDate() - (day - 1)))
    var sundayTime = new Date(mondayTime.getFullYear(), mondayTime.getMonth(), mondayTime.getDate() + 6)
    return [parseToPhpDate(mondayTime), parseToPhpDate(sundayTime)]
}
console.log(countDayNum2()) // ["2019-03-18", "2019-03-24"]
6)根据当前日期获取当前是今年的第几周
// 根据当前日期获取当前是今年的第几周
function countCurweeknum() {
    var curDate = new Date()
    var first = new Date(curDate.getFullYear(), 0, 1) // 获取当前年份第一天的日期
    while (first.getDay() !== 1) { // 获取当前年份第一个周一的日期
         first.setDate(first.getDate() + 1)
    }
    // 获取当前日期上一个周日的日期
    var last = new Date(curDate.setDate(curDate.getDate() - (curDate.getDay() === 0 ? 7 : curDate.getDay())))
    // 利用时间戳计算天数
    var weekNum = Math.ceil((last.getTime() - first.getTime()) / (7 * 1000 * 24 * 60 * 60)) + 1
    return weekNum
}
console.log(countCurweeknum()) // 11 2019-03-21
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,922评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,591评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,546评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,467评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,553评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,580评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,588评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,334评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,780评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,092评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,270评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,925评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,573评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,194评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,437评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,154评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,127评论 2 352

推荐阅读更多精彩内容