js日期格式化,日期时间计算整理

js日期格式化,日期时间计算整理

功能列表:

  • 日期格式化
  • 计算日期差值
  • 计算日期+n天
  • 计算日期+n月
  • 计算日期+n年
  • 获得本季度的开始月份
  • 获得周一
  • 获得周日
  • 获得月初
  • 获得月末
  • 获得季度初
  • 获得季度末
  • 获得年初
  • 获得年末

工具类:


class DateUtils {
  /**
   * 格式化日期
   * @param {*} date 日期
   * @param {*} formatter 格式
   * @returns 格式化日期
   */
  static formatDate(date, formatter) {
    if (!date) {
      return ''
    }
    if (!(date instanceof Date)) {
      date = new Date(date)
    }
    const y = date.getFullYear()
    // 这里month得加1
    const m = `${date.getMonth() + 1}`.padStart(2, 0)
    const d = `${date.getDate()}`.padStart(2, 0)
    const hh = `${date.getHours()}`.padStart(2, 0)
    const mm = `${date.getMinutes()}`.padStart(2, 0)
    const ss = `${date.getSeconds()}`.padStart(2, 0)
    const SSS = `${date.getMilliseconds()}`.padStart(3, 0)
    if (formatter) {
      return formatter
        .replace('yyyy', y)
        .replace('MM', m)
        .replace('dd', d)
        .replace('hh', hh)
        .replace('mm', mm)
        .replace('ss', ss)
        .replace('SSS', SSS)
    }
    // 默认返回 yyy-mm-dd hh:mm:ss
    return `${y}-${m}-${d} ${hh}:${mm}:${ss}`
  }

  /**
   * 计算日期差值
   * @param {*} startDate 开始日期
   * @param {*} endDate 结束日期
   * @returns 返回计算结果
   */
  static calculateDiffDate(startDate, endDate) {
    if (!startDate || !endDate) return ''
    if (!(startDate instanceof Date)) {
      startDate = new Date(startDate)
    }
    if (!(endDate instanceof Date)) {
      endDate = new Date(endDate)
    }

    const startTime = startDate.getTime()
    const endTime = endDate.getTime()
    const total = (endTime - startTime) / 1000

    const day = parseInt(total / (24 * 60 * 60)) // 计算整数天数
    const afterDay = total - day * 24 * 60 * 60 // 取得值算出天数后剩余的转秒数
    const hour = parseInt(afterDay / (60 * 60)) // 计算整数小时数
    const totalHour = total / (60 * 60) // 换算小时数
    const afterHour = total - day * 24 * 60 * 60 - hour * 60 * 60 // 取得算出小时数后剩余的秒数
    const min = parseInt(afterHour / 60) // 计算整数分
    const totalMin = total / 60 // 换算分钟数据
    const afterMin = total - day * 24 * 60 * 60 - hour * 60 * 60 - min * 60 // 取得算出分后剩余的秒数

    const result = {
      day,
      afterDay,
      hour,
      totalHour,
      afterHour,
      min,
      totalMin,
      afterMin
    }
    return result
  }

  /**
   * 日期+天
   * @param {*} day
   * @param {*} n
   * @returns
   */
  static AddDays(day, n) {
    if (!day) {
      return ''
    }
    const t = new Date(day)

    t.setDate(t.getDate() + n)
    return t
  }

  /**
   * 日期+月。日对日,若目标月份不存在该日期,则置为最后一日
   * @param {*} day
   * @param {*} n
   * @returns
   */
  static AddMonths(day, n) {
    if (!day) {
      return ''
    }
    const t = new Date(day)
    const s = new Date(day)

    t.setMonth(t.getMonth() + n)
    if (t.getDate() !== s.getDate()) {
      t.setDate(0)
    }
    return t
  }

  /**
   * 日期+年。月对月日对日,若目标年月不存在该日期,则置为最后一日
   * @param {*} day
   * @param {*} n
   * @returns
   */
  static AddYears(day, n) {
    if (!day) {
      return ''
    }

    const t = new Date(day)
    const s = new Date(day)
    t.setFullYear(t.getFullYear() + n)
    if (t.getDate() !== s.getDate()) {
      t.setDate(0)
    }
    return t
  }

  /**
   * 获得本季度的开始月份
   * @param {*} dateMonth
   * @returns
   */
  static getQuarterStartMonth(date) {
    if (!date) {
      return ''
    }
    const t = new Date(date)
    const dateMonth = t.getMonth()

    if (dateMonth <= 2) {
      return 0
    }
    if (dateMonth <= 5) {
      return 3
    }
    if (dateMonth <= 8) {
      return 6
    }
    return 9
  }

  /**
   * 周一
   *
   * @param {*} date
   * @param {*} dateDayOfWeek
   * @returns
   */
  static getWeekStartDate(date) {
    if (!date) {
      return ''
    }
    const t = new Date(date)
    // 今天是本周的第几天。周一=0,周日=6
    const dateDayOfWeek = t.getDay() === 0 ? 6 : t.getDay() - 1

    return DateUtils.AddDays(date, -dateDayOfWeek)
  }

  /**
   * 周日。本周一+6天
   * @returns
   */
  static getWeekEndDate(date) {
    return DateUtils.AddDays(DateUtils.getWeekStartDate(date), 6)
  }

  /**
   * 月初
   * @param {*} dateYear
   * @param {*} dateMonth
   * @returns
   */
  static getMonthStartDate(date) {
    if (!date) {
      return ''
    }
    const t = new Date(date)

    const dateYear = t.getFullYear()
    const dateMonth = t.getMonth()

    return new Date(dateYear, dateMonth, 1)
  }

  /**
   * 月末。下月初-1天
   * @returns
   */
  static getMonthEndDate(date) {
    return DateUtils.AddDays(DateUtils.AddMonths(DateUtils.getMonthStartDate(date), 1), -1)
  }

  /**
   * 季度初
   * dateYear = date.getFullYear()
   * @param {*} dateYear
   * @returns
   */
  static getQuarterStartDate(date) {
    if (!date) {
      return ''
    }
    const t = new Date(date)

    const dateYear = t.getFullYear()

    return new Date(dateYear, DateUtils.getQuarterStartMonth(date), 1)
  }

  /**
   * 季度末。下季初-1天
   * @returns
   */
  static getQuarterEndDate(date) {
    return DateUtils.AddDays(DateUtils.AddMonths(DateUtils.getQuarterStartDate(date), 3), -1)
  }

  /**
   * 年初,1-1
   * @param {*} date
   * @returns
   */
  static getYearDateStart(date) {
    if (!date) {
      return ''
    }
    const t = new Date(date)
    const dateYear = t.getFullYear()
    return new Date(dateYear, 0, 1)
  }

  /**
   * 年末 12-31
   * @param {*} date
   * @returns
   */
  static getYearDateEnd(date) {
    if (!date) {
      return ''
    }
    const t = new Date(date)
    const dateYear = t.getFullYear()
    return new Date(dateYear, 11, 31)
  }
}

export default DateUtils

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值