我正在尝试从角度UI日历构建一周调度程序,但不断收到错误:"无法读取null的属性"格式",并且我的事件列表都没有显示。导入所有依赖项,我在索引上声明 ui 日历.html如下所示:
<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']
);
日历显示在页面上,但没有我的硬编码事件(事件在我的控制器中声明)。我这里有一个这个调度程序的堆积器:https://plnkr.co/edit/Plscx3IiZb5h9cE7Wdv6?p=preview
我已经搜索了很多相关问题,但找不到解决此问题的方法。如何正确呈现这些事件?
Cannot read property "format" of null
是与开始或结束时间相关的错误 - 完整日历正在尝试格式化您的日期并失败。 这是因为 Plunker 中显示的事件将开始和结束日期指定为 Javascript Date
对象:
{title: 'All Day Event',start: new Date(y, m, 6),allDay:true},
这不是 Fullcalendar 要求的格式 - 如文档所述,您需要使用:
一个类似 Moment 的输入,如ISO8601字符串。
ISO8601字符串看起来像2017-10-18
. 如果你想坚持使用Javascript的Date
,一个快速的解决方法是使用toISOString()
:
{title: 'All Day Event', start: new Date(y, m, 6).toISOString(), allDay:true},
您也可以切换到使用Moment,这是Fullcalendar所必需的,因此已经可用:
{title: 'All Day Event', start: moment().date(6), allDay:true},