我有一个 mongoDB 脚本,我每天都在其中迭代并运行一些计算。我在 3 月 13 日左右遇到了一些意外行为,我认为这是夏令时。我的代码看起来像这样:
var startDate = ISODate("2016-01-02T00:00:00Z")
var endDate = ISODate("2019-03-18T00:00:00Z")
while(startDate < endDate){
print(startDate);
startDate.setDate(startDate.getDate() + 1)
}
3 月 13 日之前的输出符合预期:
ISODate("2016-03-11T00:00:00Z")
ISODate("2016-03-12T00:00:00Z")
ISODate("2016-03-13T00:00:00Z")
ISODate("2016-03-13T23:00:00Z") <----- here
ISODate("2016-03-14T23:00:00Z")
我希望每个日期都在同一时间 (T00:00:00
)。谁能建议解决这个问题的方法?我应该考虑使用不同的方法来增加日期吗?
最佳答案
您需要始终如一地使用UTC
,您可以使用Date.UTC
来做到这一点。打印数据时需要使用toISOString()
var startDate = Date.UTC(2016, 2, 10);
var endDate = Date.UTC(2016, 2, 30);
while (startDate < endDate) {
document.write(new Date(startDate).toISOString()+'<br>');
startDate = startDate + 86400000
}
关于javascript - 如何遍历几天并考虑夏令时?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35295651/