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

相关文章:

  • 2022-12-23
  • 2022-12-23
  • 2022-02-01
  • 2021-06-10
  • 2021-12-05
  • 2022-12-23
  • 2021-07-21
  • 2022-01-28
猜你喜欢
  • 2021-12-19
  • 2021-06-25
  • 2021-04-07
  • 2021-04-29
  • 2021-08-04
  • 2022-12-23
  • 2022-12-23
相关资源
相似解决方案