最近用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.cspublic 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的转换,很好用的。

posted on 2008-05-05 09:22  @清风......  阅读(4835)  评论(13编辑  收藏  举报