asp.net检索由JSON.stringify转换的原始日期值

时间:2015-10-05 10:07:42

标签: javascript asp.net kendo-asp.net-mvc

我们之前的开发人员创建了一个通用方法,用于检索具有更新/更改的所有用户输入。 它看起来像这样(用户端/ JavaScript / Kendo):

param._updated = JSON.stringify(rows._updated);

我有点绝望,当* rows._updated包含日期值叔叔JSON将其转换为其他String格式,导致 DateTime 差异例如:

dateField = 11/1/2015  // <--Original User Input
rows._updated = { dateField: November 1, 2015 0:00:00 GMT+080 ... }
param._updated =  { "dateField": "2015-10-31T16:00:00.0000Z"... }

现在会导致冲突。 由于上面的代码是可能包含不同数据和类型的通用字段,我试图在服务器端解决这个问题,但我没有达到原始日期值。

注意:我们的用户有2-5个不同的时区,因此很难对转换进行硬编码。 相关问题:here

现在已经很晚了。提前致谢!。

1 个答案:

答案 0 :(得分:0)

我通过以下方法实现了我想要的目标

1。)在后端将DateTime转换为UTC格式

string dateUTC = paramDate.ToString("yyyy'-'MM'-'dd'T'HH':'mm':'ss'.'fff'Z'");

2。)现在我已经创建了一个方法来处理UTC Date转换为PlainDate

        public static string UTCtoPlainDate(string dateUTC)
    {
        if (string.IsNullOrEmpty(dateUTC)) return "";
        DateTime dateTime;
        // Assume date in UTC format, e.g. '2015-03-31T12:00:00.000Z'
        DateTime.TryParseExact(dateUTC, "yyyy-MM-dd'T'HH:mm:ss.fff'Z'", System.Globalization.CultureInfo.InvariantCulture,
            System.Globalization.DateTimeStyles.AssumeUniversal, out dateTime);

        return dateTime.ToString("yyyy-MM-dd") ?? "";
    }