Fullcalendar:可拖动对象拒绝Fullcalendar作为可丢弃对象,即使fullcalenda接受丢弃



我已经设置了FullCalendar来接受drop,它确实这样做了。但是,我用revert构建的可拖动对象:'invalid'似乎无法识别FullCalendar上的日期是可丢弃的,而是返回。这是我的代码:

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html><head>
  <meta content="text/html; charset=ISO-8859-1" http-equiv="content-type">
  <title>mydrag</title>
  <script src="fullcalendar-bundle.js" type="text/javascript"></script>
</head><body>
<div id="mydrag" style="width: 200px; height: 100px; background-color: red;">My Drag</div>
<div id="calendar"></div>

<script type="text/javascript">
function onExternalEventDrop(date, allDay) {
    alert("Dropped on " + date + " with allDay=" + allDay);
}
$('#mydrag').each(function() {
    // create an Event Object (http://arshaw.com/fullcalendar/docs/event_data/Event_Object/)
    // it doesn't need to have a start or end
    var eventObject = {
        title: 'MyDrag Title'
    };
    // store the Event Object in the DOM element so we can get to it later
    $(this).data('eventObject', eventObject);
    // make the event draggable using jQuery UI
    $(this).draggable({
        helper: 'clone',
        //revert: 'invalid',
        revert: function(droppableObj) {
            //if false then no socket object drop occurred.
            if(droppableObj === false) {
                //revert the .myselector object by returning true
                alert('Not a droppable object');
                return true;
            }
            else {
                //droppableObj was returned,
                //we can perform additional checks here if we like
                //alert(droppableObj.attr('id')); would work fine
                //return false so that the .myselector object does not revert
                return false;
            }
         },
        revertDuration: 500,  //  original position after the drag
        start: function(e, ui) {
            $(ui.helper).css('width', $(this).css('width'));
        }
    });
});
$('#calendar').fullCalendar({
    aspectRatio: 2.25,
    header: {
        left: '',
        center: 'title',
        right: 'prev,next'
    },
    columnFormat: {
        month: 'dddd'
    },
    droppable: true,
    drop: onExternalEventDrop
});
</script>
</body></html>

当我将可拖动元素拖到日历上时,该元素会返回(这表明日历日期未被识别为有效的可丢弃日期)。。。。但是drop回调是由预期的警报触发的(这表明FullCalendar将draggable识别为有效)。我希望"拖拉者"不会回头。我是在做什么还是在期待什么?我到处找了一遍,但没有找到任何解释。如有任何帮助,我们将不胜感激。

更新:忘了提一下,我称之为"fullcalendarybundle.js"的是一个包含以下内容的文件:

  • jquery 1.5.2
  • jquery ui 1.8.11
  • fullcalendar 1.5.2插件

另一个更新:我刚刚尝试了FullCalendar 1.5.3版本,但看到了相同的行为。

这可能会对您有所帮助:

拖放的工作版本:http://jsfiddle.net/wkKfB/15/

dragobj=false的解决方案是您需要将可丢弃事件绑定到日历,以便可拖动知道什么是DOM对象可以丢弃请参阅此处的工作示例:http://jsfiddle.net/CZQkm/3/&amp;http://jsfiddle.net/DEsdN/12/*在此之前

您的版本,但有一些调整。顺便说一下,我在这里处理了您的问题:http://jsfiddle.net/wkKfB/16/)(问题是绑定外部事件)

良好的文档位于此处:http://arshaw.com/fullcalendar/docs/dropping/droppable/

问题是您需要从外部添加这些拖动事件。

您可以更改css并将其用于您的用途。

报价*[来自上面关于外部拖放的文档。]*http://arshaw.com/fullcalendar/docs/dropping/droppable/

>     How can I use this to add events???
>     
>     Good question. It is a common need to have an "external list of events" that can be dragged onto the calendar.
>     
>     While the droppable option deals with generic jQuery UI draggables and is not specifically tailored to adding events, it is possible to
> achieve this with a few lines of code. Follow the
> external-dragging.html example in FullCalendar's download. You can
> also view the example online.
>     
>     In short, you must call renderEvent yourself in the drop callback.

另一个链接:http://arshaw.com/js/fullcalendar-1.5.3/demos/external-dragging.html

要捕获外部事件,您需要添加此代码,但上面的示例已经为您设置好了,应该很清楚

 /* initialize the external events
    -----------------------------------------------------------------*/
$('#external-events div.external-event').each(function() {
    // create an Event Object (http://arshaw.com/fullcalendar/docs/event_data/Event_Object/)
    // it doesn't need to have a start or end
    var eventObject = {
        title: $.trim($(this).text()) // use the element's text as the event title
    };
    // store the Event Object in the DOM element so we can get to it later
    $(this).data('eventObject', eventObject);
    // make the event draggable using jQuery UI
    $(this).draggable({
        zIndex: 999,
        revert: true,      // will cause the event to go back to its
        revertDuration: 0  //  original position after the drag
    });
});

/* initialize the calendar
-----------------------------------------------------------------*/

相关内容

  • 没有找到相关文章