Epoch时间.NET到JavaScript(小时?)

时间:2011-10-05 00:11:00

标签: javascript .net vb.net unix-timestamp

在.NET中使用以下代码

Input: "2011-09-14 00:00:00.0000000" (From an SQL datebase loaded into a Date datetype becoming #9/14/2011#)

<Extension()>
Public Function ToEpoch(value As Date) As Double
    Dim span As TimeSpan = (value - New Date(1970, 1, 1, 0, 0, 0, 0).ToLocalTime)
    Return span.TotalMilliseconds
End Function

这在JavaScript中

var StartDate = new Date(<%= StartDate() %>);

导致此输出

var StartDate = new Date(1315922400000);

看来只有这个特定的输入,StartDate(在javascript端)正好一个小时。

导致JavaScript日期时间为:Tue Sep 13 23:00:00 UTC+1000 2011

如果我输入Date.Now之类的值,它似乎正常运行。

我认为我缺少一些基本的东西?

2 个答案:

答案 0 :(得分:4)

在我看来,unix时代是1970年1月1日,UTC。

鉴于此,您创建日期然后转换为当地时间有点倒退。您需要做的是将可变时间值转换为UTC。

<Extension()>
Public Function ToEpoch(value As Date) As Double
    Dim span As TimeSpan = (value.ToUniversalTime - 
                                New System.DateTime(1970, 1, 1, 0, 0, 0, DateTimeKind.Utc))
    Return span.TotalMilliseconds
End Function

您可能认为这两种转换是等效的,但它们可能不是,如中所述 http://blogs.msdn.com/b/oldnewthing/archive/2003/10/24/55413.aspx

答案 1 :(得分:3)

我怀疑这两个日期有不同的夏令时值。查看以下对IsDaylightSavingTime()的调用是否返回相同的值:

Dim dt As Date = new Date(2011, 9, 14)
Dim epoch As Date = new Date(1970, 1, 1)

dt.IsDaylightSavingTime()
epoch.IsDaylightSavingTime()