Newtonsoft.Json 时间转换问题的改进

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

转自:http://www.cnblogs.com/caizhiyuan/archive/2008/05/05/1182753.html

posted @ 2008-05-09 09:39 hehuachina 阅读(140) 评论(0)  编辑 收藏 网摘 所属分类: JSON



发表评论

昵称: [登录] [注册]

主页:

邮箱:(仅博主可见)

评论内容:

  登录  注册

[使用Ctrl+Enter键快速提交评论]

0 1189440




相关文章:

相关链接: