数据之events(json)
优质
小牛编辑
136浏览
2023-12-01
返回json格式数据的接口,每当FullCalendar需要的数据的时候就会访问这个地址(例如用户在当前视图前进或者后退,或者切换视图),FullCalendar会判断需要的时间段,并且把这个时间放在get请求
$('#calendar').fullCalendar({ events: '/myfeed.php' });
/myfeed.php?start=1262332800&end=1265011200&_=1263178646
_参数是自动生成的,防止接口缓存数据。跨域请求使用JSONP。
1.5版本之后,可以使用 Event Source options,如下:
$('#calendar').fullCalendar({ eventSources: [ // your event source { url: '/myfeed.php', // use the `url` property color: 'yellow', // an option! textColor: 'black' // an option! } // any other sources... ] });
常用的Event Source设置可以查看这里。但是对于 json 数据源,还有以下两个属性:
startParam | 设置此Event Source下的 startParam |
endParam | 设置此Event Source下 |
JQuery $.ajax
你可以使用任何的JQuer ajax属性在 eventSource 对象中:
$('#calendar').fullCalendar({ eventSources: [ // your event source { url: '/myfeed.php', type: 'POST', data: { custom_param1: 'something', custom_param2: 'somethingelse' }, error: function() { alert('there was an error while fetching events!'); }, color: 'yellow', // a non-ajax option textColor: 'black' // a non-ajax option } // any other sources... ] });
上面是例子用单一event的写法是:
$('#calendar').fullCalendar({ events: { url: '/myfeed.php', type: 'POST', data: { custom_param1: 'something', custom_param2: 'somethingelse' }, error: function() { alert('there was an error while fetching events!'); }, color: 'yellow', // a non-ajax option textColor: 'black' // a non-ajax option } });
动态data属性
通过GET或者POST发送出去的data属性,可以通过函数动态的设置:
$('#calendar').fullCalendar({ events: { url: '/myfeed.php', data: function() { // a function that returns an object return { dynamic_value: Math.random() }; } } });
startParam 和 endParam 依然会自动添加。
缓存
默认的,会有个_参数来防止缓存的影响。FullCalendar通过设置 $.ajax 来实现这一点。如果你不想这么用,可以把 cache 设置为 true:
$('#calendar').fullCalendar({ events: { url: '/myfeed.php', cache: true } });
官方英文文档:http://arshaw.com/fullcalendar/docs/event_data/events_json_feed/