1

我试图要求可选择的事件在 fullCalendar 中具有固定的持续时间(例如,您可以每隔两小时预订一辆皮卡车),并且可以每半小时开始一次选择(例如,您可以从 10:00 开始预订-12:00 或 10:30-12:30)。我正在尝试将 snapDuration 用于前者,将 slotDuration 用于后者。

我尝试为日历对象设置 slotDuration 和 snapDuration 属性,但是每当我选择日历上的单元格时,它都会使用 slotDuration。我还寻找了已经可以使用的示例,但所有可用的示例都适用于旧版本的 fullCalendar。

我将 main.min.js 文件用于以下代码的核心、交互、daygrid 和 timegrid。我还在https://codepen.io/anon/pen/gJXXpw设置了一个 codepen

document.addEventListener('DOMContentLoaded', function() {
  var calendarEl = document.getElementById('calendar');

  var calendar = new FullCalendar.Calendar(calendarEl, {
    plugins: [ 'interaction', 'dayGrid', 'timeGrid' ],
    defaultView: 'timeGridWeek',
    selectable:true,
    select:function(info){
      alert("I'm hoping that it will snap to two hours before I do other stuff inside this function.");
    },
    slotDuration: '00:30',
    snapDuration: '02:00',
    defaultDate: '2019-05-21',
    header: {
      left: 'prev,next today',
      center: 'title',
      right: 'dayGridMonth,timeGridWeek,timeGridDay'
    },
    events: [
      {
        title: 'Birthday Party',
        start: '2019-05-20T07:00:00'
      },
      {
        title: 'Click for Google',
        url: 'http://google.com/',
        start: '2019-05-22'
      }
    ]
  });

  calendar.render();
});

在选择时间间隔以将事件添加到日历时,我希望它“捕捉”到 snapDuration 值(例如,2 小时),但它仅受 slotDuration (例如,30 分钟)的限制。我可以添加一些额外的 javascript 来获得我需要的约束,但如果可能的话,我更愿意用 fullcalendar 本地处理这个。

4

1 回答 1

3

它没有在文档中明确说明,但似乎只有在其持续时间小于该值snapDuration时才会生效。slotDuration

例如,在您的演示中,如果将 更改slotDuration为 4 小时,现在您可以选择标记时间之间的 2 小时间隔。

slotDuration: '04:00',
snapDuration: '02:00',

更新的演示:https ://codepen.io/anon/pen/EzojoE

于 2019-05-23T23:03:16.223 回答