获取new Date()实例但将时间设置为午夜的最简单方法是什么?


当前回答

如果用日期计算,夏季时间通常会比午夜(CEST)多1小时或少1小时。当日期返回时,这将导致1天的差异。所以日期必须四舍五入到最近的午夜。所以代码将是(感谢jamisOn):

    var d = new Date();
    if(d.getHours() < 12) {
    d.setHours(0,0,0,0); // previous midnight day
    } else {
    d.setHours(24,0,0,0); // next midnight day
    }

其他回答

对象配置的一行代码:

new Date(new Date().setHours(0,0,0,0));

创建元素时:

dateFieldConfig = {
      name: "mydate",
      value: new Date(new Date().setHours(0, 0, 0, 0)),
}

只是在这里添加这个,因为我在这个页面上寻找如何在moment.js中做到这一点,其他人也可能会这样做。

[理由:“时刻”这个词已经出现在本页的其他地方,所以搜索引擎直接指向这里,而moment.js的广泛应用足以保证在其他与日期相关的so问题中被提及的频率]

因此,在2.0.0及以上版本中:

date.startOf('day');

对于早期版本:

date.sod();

文档:

http://momentjs.com/docs/#/manipulating/start-of/

sehours方法可以采用可选的minutes, seconds和ms参数,例如:

var d = new Date();
d.setHours(0,0,0,0);

这将把时间设置为当前时区的00:00:00.000,如果你想在UTC时间工作,你可以使用setUTCHours方法。

使用dayjs库,你可以使用startOf('day')方法。

const dayjs = require('dayjs');

const todayAtMidnight= dayjs().startOf('day');

// Get as a native date object
console.log(todayAtMidnight.toDate());

要开始特定的一天,你可以使用以下命令:

const date = dayjs("2023-02-12").startOf('day');

如果您已经在项目中有d3.js作为依赖项,或者不介意引入它,d3-time (d3.js库在v4.0.0中是模块化的)有interval。

在将日期设置为“默认”值时,它们可能很有用,例如午夜、0.00秒、每月的第一天等。

var d = new Date(); // Wed Aug 02 2017 15:01:07 GMT+0200 (CEST)
d3.timeHour(d) // Wed Aug 02 2017 00:00:00 GMT+0200 (CEST)
d3.timeMonth(d) // Tue Aug 01 2017 00:00:00 GMT+0200 (CEST)