0

我一直在玩 Full Calendar 并让它从数据库中引入事件。当它最初呈现它们时,它会检查它们是否存储为全天事件,并根据结果将 allDay 设置为 true 或 false。

这非常有效,但是当一个新事件被放到日历上时,它应该重新获取所有事件,然后重新呈现它们,这样它们就不会全部默认为全天事件。但是,尽管调用了 refetch,但它之后的行上的重新渲染却没有。但是,如果我确实在我的浏览器控制台中调用了重新渲染行,它会将它们全部重新渲染到它们应该的样子。

所以我想我的问题是,为什么 fullcalendar 会重新获取事件但忽略重新渲染?有没有解决方法?

提前谢谢了。我的代码是:

事件的初始渲染:

editable: true,
events: "json-events-log.php",
eventRender: function(event, element) {
            if (event.event_type_id==2) {
                element.addClass("red-event");
            } else if (event.event_type_id==3) {
                element.addClass("blue-event");
            } else {
                element.addClass("green-event");
            }

            if(event.all_day == 0){
                event.allDay = false;
            } else {
                event.allDay = true;
            }

        } 

以及通过 AJAX 成功发布事件后调用的成功函数:

$.ajax({
              type: 'POST',
              url: "new_event.php",
              data: ajaxData,
              success: function(data) {
                  if (data.moved==true) {
                    alert('success');

                    $("#calendar").fullCalendar("refetchEvents");
                    $("#calendar").fullCalendar("rerenderEvents");


                    $("#updatingCal").addClass("hiddenUpdate");
                    if ($('#drop-remove').is(':checked')) {

                        $(this).remove();
                    }



                  } else {
                        $("#updatingCal").addClass("hiddenUpdate");
                        console.log('fail');
                    }

              },
              dataType: "json"
            });
4

2 回答 2

0

您需要在变量 - 中缓存日历的 jquery 选择器var calendar = $("#calendar").fullCalendar();。当您渲染日历时需要添加以下代码:

if(calendar){
    calendar.fullCalendar('destroy');
}
calendar = $("#calendar").fullCalendar({
    //your options
});
于 2013-07-22T12:08:13.457 回答
0

问题是您正在修改 eventRender 回调中的事件数据。您应该改为修改 eventDataTransform 回调中的数据!

于 2013-07-22T15:23:43.063 回答