fullCalendar:从控制器JSON获取数据

时间:2017-06-05 20:57:47

标签: javascript c# json fullcalendar

我在Visual Studio 2015中使用fullCalendar库。我无法从AJAX命令填充事件。日历上没有填充任何事件。如果我只传递一个日期时间并设置allDay = true,它将填充事件。我需要它与时间一起工作和每天多个事件。

JS代码:

$(document).ready(function () {

$(".calendar").fullCalendar
    ({
        header: {
            left: 'month,basicWeek,basicDay,today',
            center: 'title',
            right: 'prev,next'
        },
        weekends: false,
        eventLimit: true,
        theme: true,
        editable: false,
        fixedWeekCount: false,
        events: function(start, end, timezone, callback)
        {$.ajax
            ({
                type: "POST",
                contentType: "application/json; charset=utf-8",
                url: "/Calendar/GetCalendarEvents",
                dataType: 'json',
                success: function (data)
                {

                    var events = [];
                    $.each(data, function (index, value) {

                        events.push({
                            id: value['id'],
                            title: value['title'],
                            date: value['date']
                            //all data
                        });
                        console.log(value)
                    });
                    callback(events);
                },
                error: function (xhr, err) {
                    alert("ERROR! - readyState: " + xhr.readyState + "<br/>status: " + xhr.status + "<br/>responseText: " + xhr.responseText);
                }
            });

        }   });})

注意:以上代码是尝试使其正常工作的代码之一。我之前尝试过不同的编码方式。

控制器代码:

public ActionResult GetCalendarEvents()
    {
        var events = new List<VMCalendarEvents>();
        var db_events = db.PatientVisits.ToList();
        foreach(var e in db_events)
        {
            DateTime visit_start = Convert.ToDateTime(e.VisitStart);
            DateTime visit_end = Convert.ToDateTime(e.VisitEnd);

            var calEvent = new VMCalendarEvents
            {
                id = e.PatientVisitID.ToString(),
                title = "Placeholder Title" + e.PatientVisitID.ToString(),
                date = visit_start.ToShortDateString(),
                start = visit_start.ToString(),
                end = visit_end.ToString(),
                editable = true,
                allDay = false

            };
            events.Add(calEvent);
        }

        var rows = events.ToArray();
        return Json(rows, JsonRequestBehavior.AllowGet);}

Controller Code Output

JS Objects from Controller

编辑:解决了问题

因此经过一些调查后,我决定在MVC中使用Razor来解决问题。我将其放入html文件的标题中,而不是将其写入单独的JS文件中。通过实现下面的代码,我能够得到日期格式为(yyyy-MM-ddTHH:dd&amp; MM / dd / yyyy hh:mm tt)的对象:

    $(function () {

    $('#calendar').fullCalendar({
        header: {
            left: 'prev,next today',
            center: 'title',
            right: 'month,agendaWeek,agendaDay'
        },
        defaultDate: '2017-06-12',
        editable: true,
        events: '@Url.Action("GetCalendarEvents", "Calendar")',

    });

});

我使用URL Action命令调用Controller,并将JSON数据作为ActionResult返回。

1 个答案:

答案 0 :(得分:1)

Fullcalendar可能不喜欢你的斜线&#39; /&#39;在您的日期字段中。尝试连字符&#39; - &#39;代替。 文档(https://fullcalendar.io/docs/utilities/Moment/)更详细地说明了日期/时间工作的格式。

作为参考,这是我使用AJAX中的JSON的完整日历代码(注意我的事件没有结束时间,但这是可选的):

{
    $.ajax({
        url: 'example.json',
        dataType: 'json',
        success: function(doc) {
            var events = [];
            $.each(doc, function(index, element) {
                events.push({
                    title: element.title,
                    start: element.time,
        url: element.url,

                });
            });
            callback(events);
        }
    }) //ajax
    }

JSON文件(example.json):

    [
{"time": "2017-06-06 09:00:00", "title": "Get It Done in June ", "url": "http://example.org"},
{"time": "2017-06-07 14:00:00", "title": "Fighting Imposter Syndrome for Dissertating Students ", "url": "http://example.com"},
{"time": "2017-06-14 14:00:00", "title": "Entering into the Academic Conversation", "url": "http://example.biz"}
]