在.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
之类的值,它似乎正常运行。
我认为我缺少一些基本的东西?
答案 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()