最近用Extjs做一些东西,json 用 Newtonsoft.Json做转换很好用。可是时间上出了一些问题,数据库里的时间和Grid里显示的时间差8小时。
刚开始以为是Ext的问题,把ext翻了个变也没弄出来。最后干脆把数据库的时间和.net读取的时间,用Newtonsoft.Json序列化后的时间,最后再用
ext显示出来的时间作对比,才发现是Newtonsoft.Json的问题,Newtonsoft.Json转换DateTime整整快了8小时,也就是正好是我们的北京时区。
原因找到了,总算问题找出来了。Newtonsoft.Json真好是开源的,在Newtonsoft.Json源代码里查找“new Date(” 找到时间转化,发现在
JavaScriptConvert.cs 里public static string ToString(DateTime value) 函数里 DateTime value减去当前的时区就可以了,
得到当前时区可以用 (DateTime.Now - DateTime.UtcNow).TotalHours
最后函数改为
public static string ToString(DateTime value)
{
long javaScriptTicks = ConvertDateTimeToJavaScriptTicks(value.AddHours(-(DateTime.Now - DateTime.UtcNow).TotalHours));
刚开始以为是Ext的问题,把ext翻了个变也没弄出来。最后干脆把数据库的时间和.net读取的时间,用Newtonsoft.Json序列化后的时间,最后再用
ext显示出来的时间作对比,才发现是Newtonsoft.Json的问题,Newtonsoft.Json转换DateTime整整快了8小时,也就是正好是我们的北京时区。
原因找到了,总算问题找出来了。Newtonsoft.Json真好是开源的,在Newtonsoft.Json源代码里查找“new Date(” 找到时间转化,发现在
JavaScriptConvert.cs 里public static string ToString(DateTime value) 函数里 DateTime value减去当前的时区就可以了,
得到当前时区可以用 (DateTime.Now - DateTime.UtcNow).TotalHours
最后函数改为
public static string ToString(DateTime value)
{
long javaScriptTicks = ConvertDateTimeToJavaScriptTicks(value.AddHours(-(DateTime.Now - DateTime.UtcNow).TotalHours));
return "new Date(" + javaScriptTicks + ")";
}
重新编译,在试,好了
现在有很多用ext做表现层的,园子里用asp.net的也很多的把,推荐用Newtonsoft.Json做实体类集合到json的转换,很好用的。