0

我正在尝试从角度 ui 日历构建一周调度程序,但我不断收到错误消息:'无法读取 null 的属性“格式”'并且我的事件列表都没有显示。所有依赖项都已导入,我在 index.html 上声明 ui 日历,如下所示:

<body ng-controller="MainCtrl">
<div class="row" on-load="renderCalendar('myCalendar');">
  <div class="col-md-4">
    <h1>All Events</h1>
    <ul>
      <li class="event" ng-repeat="event in eventSource">
        {{event.title}}
        <button type="button" class="btn btn-danger" ng-click="removeEvent($index)"> delete</button>
        </li>
    </ul>
  </div>
  <div class="col-md-8">
    <div ui-calendar="uiConfig.calendar" ng-model="eventSource" calendar="myCalendar"></div>
  </div>
</div>

我的角度模块声明:

var app = angular.module('calendar-app',
['ngResource',
'ui.calendar']
);

日历出现在页面上,但没有我的硬编码事件(事件在我的控制器中声明)。我在这里有这个调度程序的 plunker:https ://plnkr.co/edit/Plscx3IiZb5h9cE7Wdv6?p=preview

我在相关问题上进行了很多搜索,但找不到解决此问题的方法。我怎样才能正确呈现这些事件?

4

1 回答 1

0

Cannot read property "format" of null是与开始或结束时间相关的错误 - Fullcalendar 正在尝试格式化您的日期并失败。这是因为 Plunker 中显示的事件将开始和结束日期指定为 JavascriptDate对象:

{title: 'All Day Event',start: new Date(y, m, 6),allDay:true},

这不是 Fullcalendar 需要的格式 -正如文档描述的那样,您需要使用:

Moment-ish 输入,如 ISO8601 字符串。

ISO8601 字符串看起来像2017-10-18. 如果您想坚持使用 Javascript,一个快速解决方法Date是使用toISOString()

{title: 'All Day Event', start: new Date(y, m, 6).toISOString(), allDay:true},

您也可以切换到使用 Fullcalendar 所需的 Moment,因此已经可用:

{title: 'All Day Event', start: moment().date(6), allDay:true},
于 2017-10-18T08:08:25.393 回答