在.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这样的值,它看起来运行正常。
我想我遗漏了一些基本的东西?
发布于 2011-10-05 09:12:02
在我看来unix纪元是世界协调时1970年1月1日。
鉴于此,您创建日期,然后将其转换为本地时间的做法有些倒退。您需要做的是将变量time值转换为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中所解释的那样。
发布于 2011-10-05 08:58:32
我怀疑这两个日期的夏时值不同。查看以下对IsDaylightSavingTime()的调用是否返回相同的值:
Dim dt As Date = new Date(2011, 9, 14)
Dim epoch As Date = new Date(1970, 1, 1)
dt.IsDaylightSavingTime()
epoch.IsDaylightSavingTime()https://stackoverflow.com/questions/7655407
复制相似问题