通过返回的JSON发布日期格式

本文关键字:日期 格式 布日期 返回 JSON | 更新日期: 2023-09-27 18:27:53

由于某种原因,当我在C#中对某个日期执行ToString("d"),然后将其以JSON序列化到客户端时,当我试图将该值呈现到页面时,我会得到以下文本,而不是格式化的日期:

/Date(-62135575200000)/

我搞不清楚这里发生了什么。

通过返回的JSON发布日期格式

JSON和JavaScript都没有日期文本,因此有各种约定。这就是微软的,甚至他们也将其描述为"人为的"。

你可以看到这个关于解码方法的问题。

如果来回传递日期,则需要转换值。在javascript中,

var d = new Date()
d.setTime(-62135575200000);
alert(d.toDateString());

请参阅问题"将.NET DateTime转换为JSON"和相关答案。

以下显示了对移动日期的两种方式的评论。在我的代码后面:

 [WebMethod]
 public static DateTime loadDate()
 {
     return DateTime.Now;
 }
 [WebMethod]
 public static double loadDateTicks()
 {
     return DateTime.Now.UnixTicks();
 }
 public static class ExtensionMethods
 {
    // returns the number of milliseconds since Jan 1, 1970 (useful for converting C# dates to JS dates)
    public static double UnixTicks(this DateTime dt)
    {
        DateTime d1 = new DateTime(1970, 1, 1);
        DateTime d2 = dt.ToUniversalTime();
        TimeSpan ts = new TimeSpan(d2.Ticks - d1.Ticks);
        return ts.TotalMilliseconds;
    }
 }

这种推广方式的所有功劳都归于"杨"。

我的前端测试如下:

function LoadDates() {
        $.ajax({
            url: "Default.aspx/loadDate",
            type: "POST",
            data: "{}",
            contentType: "application/json; charset=utf-8",
            success: function (msg) {
                var re = /-?'d+/;
                var d = new Date(parseInt(re.exec(msg.d)[0]));
                alert(d.toDateString());
            },
            dataType: "json"
        });
        $.ajax({
            url: "Default.aspx/loadDateTicks",
            type: "POST",
            data: "{}",
            contentType: "application/json; charset=utf-8",
            success: function (msg) {
                var dt = new Date(msg.d);
                alert(dt.toDateString());
            },
            dataType: "json"
        });
    }

您可以尝试这种方法,它将日期格式化并显示为mm/dd/yyyy格式。我面临着同样的问题,我通过使用这个解决了:

var regxformatdate = /-?'d+/;
var integerformat = regxformatdate.exec(msg.d);
var dt = new Date(parseInt(integerformat));
var newdate = dt.getMonth()+1+ "/" + dt.getDate()+"/" + dt.getFullYear();