我正在使用带有Angular UI的arshaw优秀的fullcalendar,现在我遇到了一个问题,即扩展形式的eventSource对象在作为JSON提要获取时不呈现。
使用控制器中的以下代码获取数据:
$scope.events = [
'/api/v1/users/104/events?format=cal&type=9',
'/api/v1/users/104/events?format=cal&type=10'
];
$scope.eventSources = $scope.events;
当JSON提要返回一个包含事件对象的数组时,它实际上有效:
// returned by - /api/v1/users/104/events?format=cal&type=9
[
{
url: "/#/events/86893",
start: "2013-03-15",
title: ": Event - 86893"
},
{
url: "/#/events/31348",
start: "2013-03-27T09:30Z",
title: "Event - 31348"
}
],
// returned by - /api/v1/users/104/events?format=cal&type=10
[
{
url: "/#/events/86899",
start: "2013-03-25",
title: ": Event - 86899"
},
{
url: "/#/events/31349",
start: "2013-03-17T09:30Z",
title: "Event - 31349"
}
]
但是我想指定一些选项以及事件数据,例如不同JSON提要的不同颜色。因此,我决定使用API在其extended form中返回事件源。这就是API返回的内容。
// returned by - /api/v1/users/104/events?format=cal&type=9
{
events: [
{
url: "/#/events/86893",
start: "2013-03-15",
title: "Event - 86893"
},
{
url: "/#/events/31348",
start: "2013-03-27T09:30Z",
title: "Event - 31348"
}
],
color: "#ff9900",
allDayDefault: false,
ignoreTimezone: true
},
// returned by - /api/v1/users/104/events?format=cal&type=10
{
events: [
{
url: "/#/events/86899",
start: "2013-03-25",
title: "Event - 86899"
},
{
url: "/#/events/31349",
start: "2013-03-17T09:30Z",
title: "Event - 31349"
}
],
color: "#3366FF",
allDayDefault: false,
ignoreTimezone: true
}
不幸的是,当以JSON格式提取时,不会呈现此格式。在获取扩展格式时,我将eventSources赋值更改为:
$scope.eventSources = [ $scope.events ];
如果我将原始JSON响应(使用扩展形式的事件源)从API直接剪切并粘贴到eventSources方法中,它就可以工作。当它作为JSON提要返回时,是否有可能以扩展形式使用事件源?
答案 0 :(得分:0)
可能是从API返回的eventSource不是应该使用扩展表单选项的地方,而是在用作eventSource的事件函数中。
文档声明扩展表单应该在用于调用API的Json对象中使用。
http://arshaw.com/fullcalendar/docs/event_data/events_json_feed/
如果API也返回了事件的额外选项,则需要单独设置每个选项。
目前在这篇文章中,我看到调用扩展选项的唯一位置来自返回的api数据。
我认为这应该是另一种方式。并且日历应该在它甚至请求数据之前知道扩展形式。这意味着服务器不需要返回任何额外选项,日历将按Feed和扩展选项组织事件对象。
如果你可以张贴一个插件,那么我们可以指出这一点。