正确的时间没有显示在json网格中,但在MVC编辑视图中时间是正确的

时间:2013-03-08 05:18:45

标签: asp.net-mvc json

我有一个显示电子邮件模板的JSON网格,但问题是显示的最后更改日期早于当前日期,但在MVC编辑视图中编辑该记录时,正确显示了相同的记录上次更改日期。

返回的Json格式的日期是:日期(1362686659073)

但是在相同记录的编辑页面上日期是:2013年3月7日12:04:19即日期(1362638059000)

同一天的差异大约为13.5小时。

这是我的代码将数据返回给JSON

        TemplateGridExt ext = new TemplateGridExt();
        ext.Count = client.GetPagedGridCountEmailTmpl(filter);
        ext.Data = result.EmailTmpl_Vs.ToList();
        return this.Json(ext, JsonRequestBehavior.AllowGet);

1 个答案:

答案 0 :(得分:1)

尝试以字符串等其他格式传递数据,那么它应该可以正常工作。

试试这段代码 -

首先创建一个这样的类 -

public class TimeFormatter : DateTimeConverterBase
{
    public override object ReadJson(JsonReader reader, Type objectType, object existingValue, JsonSerializer serializer)
    {
        return DateTime.Parse(reader.Value.ToString());
    }

    public override void WriteJson(JsonWriter writer, object value, JsonSerializer serializer)
    {

        writer.WriteValue(((DateTime)value).ToString("yyyy/MM/dd"));//format for date
    }
}

使用此代码将Json数据返回到您的视图 -

JsonSerializerSettings jSettings = new JsonSerializerSettings()
            {
                Formatting = Formatting.Indented,
                DateTimeZoneHandling = DateTimeZoneHandling.Utc
            };

            jSettings.Converters.Add(new TimeFormatter());
            JsonSerializer.Create(jSettings);


            return JsonConvert.SerializeObject(data, jSettings);//'data' is list of objects to return to view.

不要忘记包含名称空间 -

using System.Runtime.Serialization;
using Newtonsoft.Json;
using Newtonsoft.Json.Converters;