头图
本文介绍一下如何使用js获取指定时间对应月份的天数。

获取当前月份天数

我测试的时间是2022-09-01:

const date = new Date()
const year = date.getFullYear()
const month = date.getMonth()

const days = new Date(year,month+1,0).getDate() // 30

假如要获取2022-02的天数:

const days = new Date(2022,2,0).getDate() // 28

注意:new Date()接收的第三个参数是0,第二个参数是人类意识中的月份(因为date.getMonth()得到的值比想象中的小1)

补充

月份是从0开始计算的:

new Date('2022-01-01 13:55:33').getMonth()
// 0

获取指定日期 是 星期几:

new Date('2022-08-28 13:55:33').getDay()
// 0 星期日(老外喜欢把一周中的星期日当成第一天,也是从0开始)

应用场景

我是在使用 echarts 时遇到了这个问题,需要按月份生成数据:

具备了上面的基础知识,就可以搞定这个问题了:

function genDaysArr(timestamp) {
    const d = new Date(timestamp)
    const y = d.getFullYear()
    const m = d.getMonth()+1
    const m_str = m>10?m:'0'+m

    // 获取指定月份天数
    const days = new Date(y,m,0).getDate()
    const arr = []
    for (let i = 1; i <= days; i ++) {
        const day_str = i>=10?i:'0'+i
        arr.push({day: `${y}-${m_str}-${day_str}`, count: 0})
    }
    return arr
}

const a = genDaysArr(1647852283000)
console.log(a)

/**
[
  { day: '2022-03-01', count: 0 },
  { day: '2022-03-02', count: 0 },
  { day: '2022-03-03', count: 0 },
  { day: '2022-03-04', count: 0 },
  { day: '2022-03-05', count: 0 },
  { day: '2022-03-06', count: 0 },
  { day: '2022-03-07', count: 0 },
  { day: '2022-03-08', count: 0 },
  { day: '2022-03-09', count: 0 },
  { day: '2022-03-10', count: 0 },
  { day: '2022-03-11', count: 0 },
  { day: '2022-03-12', count: 0 },
  { day: '2022-03-13', count: 0 },
  { day: '2022-03-14', count: 0 },
  { day: '2022-03-15', count: 0 },
  { day: '2022-03-16', count: 0 },
  { day: '2022-03-17', count: 0 },
  { day: '2022-03-18', count: 0 },
  { day: '2022-03-19', count: 0 },
  { day: '2022-03-20', count: 0 },
  { day: '2022-03-21', count: 0 },
  { day: '2022-03-22', count: 0 },
  { day: '2022-03-23', count: 0 },
  { day: '2022-03-24', count: 0 },
  { day: '2022-03-25', count: 0 },
  { day: '2022-03-26', count: 0 },
  { day: '2022-03-27', count: 0 },
  { day: '2022-03-28', count: 0 },
  { day: '2022-03-29', count: 0 },
  { day: '2022-03-30', count: 0 },
  { day: '2022-03-31', count: 0 }
]
 */

只要传入对应月份的时间戳就可以生成这个月的基础数据了。

希望对你有帮助。


来了老弟
508 声望31 粉丝

纸上得来终觉浅,绝知此事要躬行