jQuery FullCalendar 未清除事件



我目前正在使用FullCalendar,它非常酷,为我做了很多巧妙的事情。我唯一的问题是,如果我编辑一个事件,然后尝试创建另一个事件时,javascript似乎会保留初始事件数据。

当我需要链接结束时,我使用的是calendar.fullCalendar("取消选择"),但无论我做什么,它似乎都没有什么区别。我希望你们能看到我忽略的东西。

<script type='text/javascript'>
    $(document).ready(function() {
        var date = new Date();
        var d = date.getDate();
        var m = date.getMonth();
        var y = date.getFullYear();
         var calendar = $('#calendar').fullCalendar({
            header: {
                left: 'prev,next today',
                center: 'title',
                right: 'month,agendaWeek,agendaDay'
            },
            defaultView: 'agendaWeek',
            selectable: true,
            unselectAuto: true,
            selectHelper: true,
            editable: true,
            select: function(start, end, allDay) {
                //var title = prompt('Event Title:');
                //var desc = prompt('Event Description:');
                //calendar.fullCalendar('unselect');    
                $('#eventStart').val(start);
                $('#eventEnd').val(end);
                $('#eventAllDay').val(allDay);
                $('#formName').fadeIn();
                $('.closeSchedule a').click(function(){
                    $('#formName').fadeOut('slow');
                    $('#calendar').fullCalendar('unselect');    
                    //alert(jsEvent);
                });
            },
            events: [
                <?php
                 $first = true;
                 foreach ($events as $event)
                 {
                    if ($first == true)
                    {
                        $comma = '';
                        $first = false;
                    }
                    else
                    {
                        $comma = ',';
                    }
                     echo $comma."
                     {
                        id: '".$event->id."',
                        title: '".addSlashes($event->title)."',
                        start: '".$event->start."',
                        end: '".$event->end."',
                        allDay: ".$event->allDay."
                    }";
                    $first = false;
                 }
                ?>
                            ],
            eventClick: function(event) {
                //alert(event.id);

                $.ajax({
                  url: './schedule/getEdit/'+event.id,
                  success: function(data) {
                    var formEmpty = $('formName').html();
                    $('#formName').html(data);
                    $('#formName').fadeIn('fast');
                    $('.closeSchedule a').click(function(){
                        $('#formName').fadeOut('slow');
                        $('#calendar').fullCalendar('unselect');
                    });
                    $('#deleteEvent').live('click', function(){
                        var answer = confirm("Are you sure you wish to delete this event?")
                        if (answer){
                            $.ajax({
                               type: "POST",
                               url: "./schedule/deleteEvent/"+event.id,
                               success: function(msg){
                                  $('#formName').fadeOut('fast');            
                                  calendar.fullCalendar( 'removeEvents', [event.id ] )
                                  $('#calendar').fullCalendar('unselect');
                               }
                            });
                        }
                    }); 
                    $('#updateEvent').live('click', function(){
                        var title       = $('#eventName').val();
                        var trainerID   = $('#eventTrainer').val();
                        var trainer     = $('#eventTrainer option:selected').text();
                        var classID     = $('#eventType').val();
                        var eventType   = $('#eventType option:selected').text();
                        var eventStart  = $('#eventStart').val();
                        var eventEnd    = $('#eventEnd').val();
                        var eventAllDay = $('#eventAllDay').val();
                        if (eventAllDay == 'false')
                        {
                            allDay = false;
                        }
                        else
                        {
                            allDay = true;
                        }

                    // This runs the ajax to add the event to the database.
                    newData = 'title='+title+'&trainerID='+trainerID+'&classID='+classID+'&start='+eventStart+'&end='+eventEnd+'&allDay='+allDay
                    $.ajax({
                       type: "POST",
                       url: "./schedule/updateEvent/"+event.id,
                       data: newData,
                       success: function(msg){
                         event.title = title;
                         calendar.fullCalendar('rerenderEvents');
                         //calendar.fullCalendar('unselect');
                         $('#calendar').fullCalendar('unselect');
                       }
                     });

                    $('#formName').fadeOut('fast');
                    $('#eventName').val('');
                    $('#eventTrainer').val();
                    $('#eventType').val();  

                    });
                  }
                });
            },
            eventDrop: function(event,dayDelta,minuteDelta,allDay,revertFunc) {

                    newData = 'start='+event.start+'&end='+event.end+'&allDay='+allDay
                    $.ajax({
                       type: "POST",
                       url: "./schedule/updateEventTime/"+event.id,
                       data: newData,
                       success: function(msg){
                       }
                     }); 
            },
            eventResize: function(event,dayDelta,minuteDelta,revertFunc) {
                newData = 'start='+event.start+'&end='+event.end+'&allDay='+event.allDay
                $.ajax({
                   type: "POST",
                   url: "./schedule/updateEventTime/"+event.id,
                   data: newData,
                   success: function(msg){
                   }
                 }); 
            }
        }); 

        $('#submitEvent').click(function(){
                    $('#calendar').fullCalendar('unselect');
                    var title       = $('#eventName').val();
                    var trainerID   = $('#eventTrainer').val();
                    var trainer     = $('#eventTrainer option:selected').text();
                    var classID     = $('#eventType').val();
                    var eventType   = $('#eventType option:selected').text();
                    var eventStart  = $('#eventStart').val();
                    var eventEnd    = $('#eventEnd').val();
                    var eventAllDay = $('#eventAllDay').val();
                    if (eventAllDay == 'false')
                    {
                        allDay = false;
                    }
                    else
                    {
                        allDay = true;
                    }

                    // This runs the ajax to add the event to the database.
                    newData = 'title='+title+'&trainerID='+trainerID+'&classID='+classID+'&start='+eventStart+'&end='+eventEnd+'&allDay='+allDay
                    $.ajax({
                       type: "POST",
                       url: "./schedule/addEvent",
                       data: newData,
                       success: function(msg){
                         var description = '<ol><li>'+title+'</li><li>'+trainer+'</li><li><a href="#" target="_blank">'+eventType+'</a></li><li class="eventID hide">'+msg+'</li>';
                         calendar.fullCalendar('renderEvent',
                            {
                                id: msg,
                                title: title,
                                description: description,
                                start: eventStart,
                                end: eventEnd,
                                allDay: allDay
                            },
                            true // make the event "stick"
                         );

                         calendar.fullCalendar('unselect');
                         //calendar.fullCalendar( 'rerenderEvents' )
                       }
                     });

                    $('#formName').fadeOut('fast');
                    $('#eventName').val('');
                    $('#eventTrainer option:selected').removeAttr('selected');
                    $('#eventType option:selected').removeAttr('selected');

        });
    });
   </script>

在这一点上,我觉得我已经试过了,我只是希望有一双新的眼睛能看到我错过的。

Ok快速查看了一下,看起来您没有用空白表单初始化表单,以便在完整日历的"选择:"功能中进行添加操作:

在您的活动中,点击您正在执行以下操作:

$('#formName').html(data);

我看不出你在哪里用一张新活动的空白表格来清除这一点。(可能只是错过了,那里有很多代码)

让我知道。

相关内容

  • 没有找到相关文章

最新更新