我正在尝试将fullCalendar
事件发布到我的控制器操作方法,但由于某种原因,我从视图传递到控制器的json将变为null。我尝试了所有可能的组合,比如将动作参数更改为我的模型类型,字符串类型甚至传递简单的jason,所有都在我的动作参数中变为null。这是我的Ajax代码和控制器方法,我相信这是一个小问题,但我无法弄清楚我做错了什么。
$("#calendar").fullCalendar({
header: {
left: 'prevYear,prev,next,nextYear',
center: 'title',
right: 'month,agendaWeek,agendaDay',
},
defaultView: 'month',
editable: true,
alldayslot: false,
selectable: true,
slotminutes: 15,
nextDayThreshold: "00:00:00",
events: "/Home/FullCalendar",
eventDrop: function(event, delta, revertFunc)
{
if (confirm("Even changed")) {
Update(event);
}
else revertFunc();
},
});
function Update(event) {
var datarow = new Object();
datarow.TaskId = event.id;
datarow.StartDate = event.start;
datarow.EndDate = event.end;
debugger;
$.ajax({
type: "post",
dataType: "json",
contentType: "application/json; charset=utf-8",
data: JSON.stringify(datarow),
url: "/Home/UpdateTask",
success: function (data) {
debugger;
},
error: function (xhr, ajaxOptions, thrownError) {
alert(xhr.status);
debugger;
}
});
}
});
我的控制器方法
[HttpPost]
public void UpdateTask(Tasks td)
{
// Update event in database
}
答案 0 :(得分:0)
这是我最初的工作方式(现在变化很大,很棒的插件是FullCalendar)。
$(document).ready(function () {
var calendar = $('#calendar').fullCalendar({
events: '/BookingTwo/GetDiaryEvents/',
header: {
left: 'prev,next today',
center: 'title',
right: 'month,agendaWeek,agendaDay'
},
defaultView: 'month',
editable: false,
contentHeight: 700,
selectable: false,
eventClick: function (event, jsEvent, view) {
var mywhen = moment(event.start).format('MMM Do h:mm A') + ' - ' + moment(event.end).format('MMM Do h:mm A');
$("#startTime").html(moment(event.start).format('MMM Do h:mm A'));
$("#endTime").html(moment(event.end).format('MMM Do h:mm A'));
$('#modalTitle').html(event.title);
$('#modalBody').html(event.description);
$('#etad').html(event.etad);
$('#etadsub').html(event.etadsub);
$('#when').text(mywhen);
$('#fullCalModal').modal();
},
dayClick: function (date, allDay, jsEvent, view) {
var mywhen = moment(event.start).format('MMM Do h:mm A') + ' - ' + moment(event.end).format('MMM Do h:mm A');
$("#customId").html(moment(event.start).format('MMM Do h:mm A'));
$("#LeaveStart").html(moment(event.start).format('MMM Do h:mm A'));
$("#LeaveFinish").html(moment(event.end).format('MMM Do h:mm A'));
$('#title').html(event.title);
$('#StaffID').html(event.userId);
$('#selectrole').html(event.RowId);
$('#customdescription').html(event.description);
$('#sicktype').html(event.ETADType);
$('#sicksub').html(event.ETADSubType);
$('#eventstatus').html(event.EventStatus);
$('#when').text(mywhen);
$('#popupEventForm').modal();
}
});
$('#btnPopupCancel').click(function () {
ClearPopupFormValues();
$('#popupEventForm').hide();
});
$('#btnPopupSave').click(function () {
$('#popupEventForm').hide();
var dataRow = {
'Id': $('#customId').val(),
'Subject': $('#title').val(),
'Description': $('#customdescription').val(),
'StartTime': $('#LeaveStart').val(),
'EndTime': $('#LeaveFinish').val(),
'SelectRole': $('#SelectRole').val(),
//'Recurrence': $('#eventDuration').val(),
//'AllDay': $('#eventDuration').val(),
//'AllRoles': $('#eventDuration').val(),
'ETADType': $('#SicknessType').val(),
'ETADSubType': $('#SicknessSubType').val(),
//'RecurrenceRule': $('#eventDuration').val(),
//'EventDate': $('#eventDuration').val(),
'StaffID': $('#StaffID').val(),
//'EventStatus': $('#EventStatus').val()
//'Duration': $('#eventDuration').val(),
//'colourId': $('#eventDuration').val()
}
ClearPopupFormValues();
$.ajax({
type: 'POST',
url: "/BookingTwo/SaveEvent",
data: dataRow,
success: function (response) {
if (response == 'True') {
$('#calendar').fullCalendar('refetchEvents');
alert('New event saved!');
}
else {
alert('Error, could not save event!');
}
}
});
});
function ShowEventPopup(date) {
ClearPopupFormValues();
$('#popupEventForm').show();
$('#title').focus();
}
function ClearPopupFormValues() {
$('#customId').val("");
$('#title').val("");
$('#LeaveStart').val("");
$('#LeaveFinish').val("");
}
function UpdateEvent(EventID, EventStart, EventEnd) {
var dataRow = {
'id': EventID,
'NewEventStart': EventStart,
'NewEventEnd': EventEnd
}
$.ajax({
type: 'POST',
url: "/BookingTwo/UpdateEvent",
dataType: "json",
contentType: "application/json",
data: JSON.stringify(dataRow)
});
}
});
这是当前的控制器动作
[HttpPost]
public ActionResult SaveEvent(DiaryEvent events)
{
try
{
int submit = bookingService.Insert(events);
//get record here to check if inserted
if(submit > 0)
{
}
}
catch(Exception ex)
{
ErrorLog.Capture(ex);
return new HttpStatusCodeResult(HttpStatusCode.InternalServerError);
//return some shit
}
return new HttpStatusCodeResult(HttpStatusCode.Created);
}