使用JSON传递时,日期更改为本地时间

时间:2010-09-01 17:51:05

标签: c# .net ajax json

我有一个显示对象数据的页面。我正在加载对象服务器端,并通过使用json的AJAX调用传递结果。有一个date属性是该对象的一部分。出于某种原因,日期正在改变。看起来它试图考虑我所在的时区并从日期减去4小时(我在EST,与GMT的差异为-4)。

当我单击消息的“显示”按钮时,它会进行AJAX调用以加载该消息的数据,然后显示它。

这是我的javascript代码:

function onBtnDisplayClicked(id)
{
    $.ajax({
        type: "POST",
        url: "<%= Url.Action("GetMessage") %>?id=" + id.toString(),
        success: function(data) { bindItem(data); },
        dataType: "json",
        contentType: "application/json; charset=utf-8"
    });
}


function bindItem(data) 
{
    $("#MessageID").val(data.MessageID);

    //Create a Date object from JSON date format - ex: (1230807660000-4000)
    var messageDate = new Date(parseInt(data.MessageDate.replace(/\/Date\((\d+)\)\//, '$1')));

    //Format date using DateFormat plugin (http://jacwright.com/projects/javascript/date_format)
    $("#txtMessageDate").val(messageDate.format('m/d/Y H:i'));
}

这是我的服务器端代码:

public JsonResult GetMessage(int id)
{
    Message msg = new Message();
    msg.LoadByPrimaryKey(id);

    var data = new
    {
        MessageID = msg.MessageID.Value,
        MessageDate = msg.MessageDate.Value
    };

    return new JsonResult() { Data = data };
}

这将在我的本地环境中正常工作,但不能在我的生产环境中正常工作。在我的本地环境中,服务器时间设置为EST(下午2:00)。生产时,服务器时间设置为GMT(下午6:00)。

因此,如果我正在尝试显示“09/01/2010 09:00 AM”,它将在我的本地环境中正确显示,但在生产时显示为“09/01/2010 05:00 AM”。我不确定为什么会这样做。

1 个答案:

答案 0 :(得分:0)

这可能是因为它知道日期来自哪个时区,所以从技术上讲,它们都代表了与你的时区相同的时间点......

我不完全确定你会怎么做,但是你需要覆盖在向UI呈现日期时格式化字符串时使用的时区。如果您可以访问该DateTime插件中的代码,那么我怀疑这是解决问题的地方。

对不起,这不是一个实际的答案;我只得到理论,因为我现在几乎没有JSON / AJAX经验。