我在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);}
编辑:解决了问题
因此经过一些调查后,我决定在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返回。
答案 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"}
]