切换视图时全日历崩溃

时间:2019-01-16 13:14:20

标签: fullcalendar fullcalendar-3

我正在Rails应用程序中使用Fullcalendar.js(通过fullcalendar gem https://github.com/mkhairi/fullcalendar)。

我拥有的fullcalendar.js的版本是3.8.2(通过在控制台中键入Fullcalendar,可以在chrome的检查器中找到它,并且我知道了

  

满月   {version:“ 3.8.2”,internalApiVersion:12,applyAll:ƒ,反跳:ƒ,isInt:ƒ,...…

执行以下步骤时,Fullcalendar崩溃,并且不呈现视图:

1-初始视图是周视图(agendaWeek)

2-更改日视图,例如通过选择下周的一天(d =今天+ 1周)

$('#calendar').fullCalendar('gotoDate',d);

3-将视图改回为日视图(agendaDay)

$('#calendar').fullCalendar('changeView','agendaDay');

4-将视图更改为周视图

$('#calendar').fullCalendar('changeView','agendaWeek');

它会出现以下错误,并且不会加载周视图:

fullcalendar.self- 
4ac7cb5378baf9f7c517f032032aaab305cd3b2213aacbab690c4efdc0047f46.js? 
 body=1:11974 Uncaught TypeError: Cannot read property 'minTime' of 
null
at ResourceTimeGrid.TimeGrid.computeTimeTop (fullcalendar.self- 

4ac7cb5378baf9f7c517f032032aaab305cd3b2213aacbab690c4efdc0047f46.js? 
body=1:11974)
at ResourceTimeGrid.TimeGrid.computeDateTop (fullcalendar.self- 
4ac7cb5378baf9f7c517f032032aaab305cd3b2213aacbab690c4efdc0047f46.js? 
body=1:11968)
at ResourceTimeGrid.TimeGrid.computeSegVerticals (fullcalendar.self- 
4ac7cb5378baf9f7c517f032032aaab305cd3b2213aacbab690c4efdc0047f46.js? 
body=1:12007)
at ResourceTimeGrid.TimeGrid.updateSegVerticals (fullcalendar.self- 
4ac7cb5378baf9f7c517f032032aaab305cd3b2213aacbab690c4efdc0047f46.js? 
body=1:11995)
at TimeGridFillRenderer.attachSegEls (fullcalendar.self- 
4ac7cb5378baf9f7c517f032032aaab305cd3b2213aacbab690c4efdc0047f46.js? 
body=1:14104)
at TimeGridFillRenderer.FillRenderer.renderSegs (fullcalendar.self- 
4ac7cb5378baf9f7c517f032032aaab305cd3b2213aacbab690c4efdc0047f46.js? 
body=1:6435)
at TimeGridEventRenderer.EventRenderer.renderBgSegs 
(fullcalendar.self- 
4ac7cb5378baf9f7c517f032032aaab305cd3b2213aacbab690c4efdc0047f46.js? 
body=1:4321)
at TimeGridEventRenderer.EventRenderer.renderBgRanges 
(fullcalendar.self- 
4ac7cb5378baf9f7c517f032032aaab305cd3b2213aacbab690c4efdc0047f46.js? 
body=1:4297)
at TimeGridEventRenderer.EventRenderer.render (fullcalendar.self- 
4ac7cb5378baf9f7c517f032032aaab305cd3b2213aacbab690c4efdc0047f46.js? 
body=1:4273)
at ResourceTimeGrid.DateComponent.executeEventRender 
(fullcalendar.self- 
4ac7cb5378baf9f7c517f032032aaab305cd3b2213aacbab690c4efdc0047f46.js? 
body=1:8848)

以下是我正在使用的代码段:

$('#calendar').each(function(){
var calendar = $(this);
calendar.fullCalendar({
  header: {
    left: 'prev,next today',
    center: 'title',
    right: 'month,agendaWeek,agendaDay'
  },
  selectable: true,
  selectHelper: true,
  editable: true,
  eventLimit: true,
  defaultView: 'agendaWeek',
  locale: 'fr',
  slotDuration: '00:15:00',
  nowIndicator:true,
  defaultDate:"2019-01-14",
  displayEventTime: false,
  hiddenDays:[0],
  minTime:'06:00',
  maxTime:'23:00',
  columnHeaderFormat:"ddd D",
  views : 
  {
    month:
    {
      groupByResource:true,
    },
    agenda:
    {
      groupByDateAndResource:true,
    },
    day:
    {
      groupByDateAndResource:true,
    },
  },
  dayClick: function(date, jsEvent, view) {
    alert("dayClick");
  },
  viewRender: function(view, element) {
    console.log(view.options);
  }
  //...other callbacks, not necessary to paste them
});

非常感谢!

1 个答案:

答案 0 :(得分:1)

找到了! (至少是一种解决方法)

我正在做的事情:

script
    chmod 0755 "${MOUNTPOINT}" || true
end script

我实际上是在获取所有事件之前切换视图,这似乎是全日历的已知问题

这里是链接:

在事件获取解决之前切换视图,JS错误#3689 https://github.com/fullcalendar/fullcalendar/issues/3689

这意味着解决方法是在更改视图之前等待所有事件被获取,例如:

$('#calendar').fullCalendar('gotoDate',d);
$('#calendar').fullCalendar('changeView','agendaDay');

对我来说很好。

谢谢!

相关问题