如何使用Fullcalendar v4在数据库中保存事件

时间:2019-02-07 07:44:11

标签: fullcalendar

之前,我使用Ajax保存事件,还可以。但是现在,使用v4,我的代码无法正常工作,就像Ajax无法识别一样。有人有解决方案吗?

我在v3.09中的代码

eventDrop: function(event, delta, revertFunc) { // Déplacement d'une événement
    var date = new Date();
    if (($.fullCalendar.formatDate(event.start, "M")>=date.getMonth()+1 && $.fullCalendar.formatDate(event.start, "D")>=date.getDate()) || ($.fullCalendar.formatDate(event.start, "M")>date.getMonth()+1)) {
        $.ajax({
            url: 'php/update_events.php',
            data: 'title='+ event.title+'&start='+ $.fullCalendar.formatDate(event.start, "YYYY-MM-DD HH:mm:ss") +'&end='+ $.fullCalendar.formatDate(event.end, "YYYY-MM-DD HH:mm:ss") +'&id='+ event.id ,
            type: "POST",
            success: function(json) {
                $('#script-info').show();
                setTimeout('divOff()',1000);
            }
        });
    } else {
        alert ("Vous ne pouvez pas déplacer une absence à une date antérieure à la date du jour.");
        revertFunc();
    }
},

我在v4中的代码

eventDrop: function(info) {
    var date = new Date();

    if (calendar.formatDate(info.event.start, {month: 'numeric'})>=date.getMonth()+1 && calendar.formatDate(info.event.start, {day: 'numeric'})>=date.getDate()) {
         $.ajax({
            url: 'php/update_events.php',
            data: 'title="Test"',
            type: "POST",
            success: function(json) {
                $('#script-info').show();
                setTimeout('divOff()',1000);
            }
        });
    alert('Ok');
    } else {
        alert('Vous ne pouvez pas déplacer un créneau de sport à une date antérieure à la date du jour.');
        info.revert();
    }
}

2 个答案:

答案 0 :(得分:0)

您给我解决方案! 我已删除脚本src ='lib / jquery.min.js'脚本。

我多么愚蠢!因此,它再次起作用。很抱歉给您带来不便

答案 1 :(得分:0)

不确定这是否对其他人有帮助,但是如果您想通过Ajax在V4中保存事件,这就是我假设calEvent来自V4中的某种事件(单击,拖动等)来做的事情:

eventClick: function (calEvent) {  var cloned= jQuery.extend(true, {},calendar.getEventById( calEvent.event.id ));
cloned.start=clientEvents[i].start;
cloned.end=clientEvents[i].end;
cloned.title=clientEvents[i].title
delete cloned.jsEvent;
delete cloned.view;

上面显示了如何克隆事件(需要jquery),然后添加自定义属性,删除一些不需要的属性并最终将其转换为JSON以发送回服务器的方法。

HTH