在FullCalendar.js中以28天周期添加事件

时间:2016-12-05 17:01:04

标签: javascript jquery fullcalendar

我正在使用FullCalendar.js来显示用户输入的任务。为此,我创建了一个弹出窗口,以获取事件基本详细信息和有关重复的详细信息。事件可以每天,每周,28天,31天,30天周期重复。我已经能够为每日和每周的案例呈现事件,但我不能考虑如何在它们之间以28/30/31天呈现事件。

我的日历代码如下:

    $('#calendar').fullCalendar({
    //height: 420,
    header: {
        left: 'prev,next today',
        center: 'title',
        right: 'month,agendaWeek,agendaDay'
    },
    defaultDate: moment(),
    defaultView: 'month',
    eventRender: function (event, element, view) {
        console.log(event.start.format());
        if (event.ranges == undefined)
            return true;
        else {
            return (event.ranges.filter(function (range) {
                if (range.end == undefined)//Check if only start is given
                    return (event.end.isAfter(range.start))
                else
                    return (event.start.isBefore(range.end) &&//If both start and end date is given
                            event.end.isAfter(range.start));
            }).length) > 0;
        }
    },
    events: function (start, end, timezone, callback) {
        var events = getEvents(start, end); //This should be a JSON request
        callback(events);
    },
    eventClick: function (calEvent, jsEvent, view) {
        alert('Event: ' + calEvent.title);
        //$('#btnOpenPopUp').click();
    }
});
事件的

和json是这样的:

     {
    title: "My repeating event",
    id: 1,
    start: '10:00', // a start time (10am in this example)
    end: '14:00', // an end time (6pm in this example)
    dow: [1, 2, 3, 4, 5], // Repeat monday and thursday
    ranges: [{ 
        start: moment().startOf('month').subtract(1, 'month'), 
        end: moment().startOf('month').subtract(1, 'month').add(7, 'd'),
    }, {
        start: moment('2016-12-15', 'YYYY-MM-DD'), //all of february
        //end: moment('2016-11-01', 'YYYY-MM-DD').endOf('month'),
    } 

我需要帮助来呈现每28天后发生的任务。有什么建议吗?

1 个答案:

答案 0 :(得分:2)

也许您可以使用later.js项目(http://bunkat.github.io/later/index.html)来计算任务的发生次数。此代码示例将生成每28天两次日期之间的所有事件:

<html>
<head>
<script src="moment.js" type="text/javascript"></script>
<script src="moment-recur-min.js" type="text/javascript"></script>
<script type="text/javascript">

var recurrence = moment().recur("2016-12-06", "2017-12-06").every(28).days();
var allDates = recurrence.all("L");
console.log(allDates);
</script>
</head>
<body>

test
</body>
</html>

祝你好运