8

我正在尝试根据用户偏好设置电子邮件超时。我早上的计算工作正常,但由于日期的行为不符合预期,所以永远不会发送晚上的电子邮件。

首先,这是我用来获取时间并根据用户位置等进行调整的代码。

var time = moment();
var machineTZ = time.zone();
var userTZ = 420;
var diffTZ = userTZ - machineTZ;

var oneHour = moment(time).add('minutes', 60);

var morningRun = moment().startOf('day');
morningRun.hour(7).minute(0);
morningRun.add('minutes', diffTZ);

var eveningRun = moment().startOf('day');
eveningRun.hour(19).minute(30);
eveningRun.add('minutes', diffTZ);

我每隔一小时检查一次,看看是否该安排另一封电子邮件发送出去。现在这是硬编码的,但是当我开始添加用户首选项时,他们将能够选择他们想要的本地时间。

我一直在调试我的值以进行故障排除。这是清晨运行的作业的输出(从服务器的角度来看):

lastRun:    2013-10-12T00:06:55.088Z (this one is being run at 1 am)
morningRun: 2013-10-11T14:00:00.000Z
eveningRun: 2013-10-12T02:30:00.000Z

运行数字与我期望的一样。在两个小时内,我希望晚上的电子邮件发送出去(我的时间下午 7:30 = 第二天服务器时间凌晨 2:30)。

一个小时后再次查看,我们看到:

lastRun:    2013-10-12T01:06:58.267Z (this one is at 2 am)
morningRun: 2013-10-12T14:00:00.000Z
eveningRun: 2013-10-13T02:30:00.000Z <---- what?

突然之间,我对我晚上的计算已经翻转了日期线,即使它仍然是 10 月 12 日(还不是 10 月 13 日)。因此,我检查是否应该安排电子邮件失败,因为它现在认为我需要在 24 小时内发送电子邮件,而不是 30 分钟。

一段时间以来一直在与这种奇怪的不一致作斗争,我想我已经弄清楚它为什么会这样做,并使用上面的时区调整了我的计算,但这并没有解决问题:(。这当然看起来有点奇怪错误,因为我期望会发生这种情况:

//Today is 10/12
var eveningRun = moment().startOf('day'); //10/12/2013 - 00:00:00
eveningRun.hour(19).minute(30); //10/12/2013 - 19:30
eveningRun.add('minutes', diffTZ); //10/13/2013 - 2:30 am

这一直有效,直到某个时候它决定“今天”实际上是 10/13,并将晚间跑步改为在 10/14 进行。非常感谢帮助,或者如果这是一个错误,我很想知道我可以做些什么来解决这个问题,直到它得到解决。

4

1 回答 1

20

无需计算machineTZdiffTZ添加任何分钟。只需这样做:

moment().zone(userTZ).startOf('day').hour(7).minute(0)

但请记住,诸如420不是时区之类的值,它是时区偏移量。它仅告诉您特定时间点的偏移量是多少。由于您是单方面应用它,因此在夏令时期间您可能会得到不正确的结果。

相反,您应该尝试使用moment-timezone插件,并执行以下操作:

moment().tz("America/Los_Angeles").startOf('day').hour(7).minute(0)

另请参阅时区标签 wiki,特别是标题为“时区!= 偏移量”和“IANA/Olson 时区数据库”的部分。

于 2013-10-13T05:56:10.953 回答