首页 文章

完整的日历过滤

提问于
浏览
1

我的查看代码显示完整日历如下:

<div class="content">
    <div id='input'>
        <?php echo form_dropdown("package_id", $packagelist, "",'id="packageid"'); ?>
    </div>
    <div id='calendar'></div>
</div>

<style>
    #calendar {
        max-width: 900px;
        margin: 0 auto;
    }
</style>

<script type="text/javascript">
    $(document).ready(function() {
        $('#packageid').change(function() { //any select change on the dropdown with id country trigger this code           
         //$('#calendar').fullCalendar ('removeEvents');   
        var packageid = $('#packageid').val();
            alert(packageid);
            if(packageid !== null)
            { $('#calendar').fullCalendar({
                 //var $pid = packageid;
                header: {
                    left: 'prev,next today',
                    center: 'title',
                    right: 'month,basicWeek,basicDay'
                },
                displayEventEnd: {
                    month: true,
                    basicWeek: true,
                    "default": true
                },
                defaultDate: '2014-11-12',
                //editable: true,
                eventLimit: false, // allow "more" link when too many events

                events: 
                "<?php echo base_url('admin/schedule/scheduledetails/hel/');?>"+"/"+packageid,
            }); 
    }


        });
    });

</script>

当我第一次单击下拉选项时,过滤的事件将显示在日历上 . 但是,当我单击下拉菜单上的其他项目时,日历上不会发生任何更改 . 现在,如果我刷新页面并从下拉列表中选择另一个项目,则会显示包含已过滤事件的日历 . 现在,如果我尝试更改下拉选项,则日历上不会发生任何更改 . 我究竟做错了什么 . 我已经调用了javascript来在onchange函数之后显示日历 .

编辑2:现在我已经编辑了我的代码:

<script type="text/javascript">  
    $(document).ready(function(e)  {  
        $('#calendar').fullCalendar('removeEvents');
        $('#calendar').fullCalendar({
                header: {
                    left: 'prev,next today',
                    center: 'title',
                    right: 'month,basicWeek,basicDay'
                },
                displayEventEnd: {
                    month: true,
                    basicWeek: true,
                    "default": true
                },
                defaultDate: '2015-11-12',
                //editable: true,
                eventLimit: false, // allow "more" link when too many events

                events: "<?php echo base_url('admin/schedule/scheduledetails/json/')?>",
                 cache : false,
            }); 

});


</script>

此脚本用于最初显示整个事件的日历 .

现在,完成以下脚本来过滤事件:

<script>

     $(document).ready(function() {
        $('#packageid').change(function() { //any select change on the dropdown with id country trigger this code           
         $('#calendar').fullCalendar ('removeEvents');   
        var packageid = $('#packageid').val();
           // alert(packageid);
             $('#calendar').fullCalendar('removeEvents');

             $('#calendar').fullCalendar('addEventSource', '<?php echo base_url();?>admin/schedule/scheduledetails/hel/'+packageid); 
             //$('#calendar').fullCalendar('removeEvents');

        }); 
    });


</script>

正在发生的问题是 . 日历最初加载了整个数据 . 当我点击下拉按钮进行过滤时,过滤就会发生 . 如果我单击完整日历上的上一个或下一个按钮,那么它也可以在没有重复事件的情况下工作 . 现在,如果我从数据库中选择下一个事件,则再次完成过滤 . 但是当我单击上一个或下一个按钮时,先前下拉选择的事件加上当前下拉选择将显示在fullcalendar视图上 . 为什么会这样?我用过removeEvents . 为什么它不起作用?

2 回答

  • 0

    你调用fullCalendar来创建每次新的日历,你需要销毁它,或者只是更改源代码并刷新:

    我在这里做的是添加一个新的来源;如果你想更改/删除旧源,你可以这样做,只需将事件源保存在一个变量中,以便在'addEventSource'调用之前在'removeEventSource'调用中使用 .

    <script type="text/javascript">
        $(document).ready(function() {
    
            $('#calendar').fullCalendar({
                    header: {
                        left: 'prev,next today',
                        center: 'title',
                        right: 'month,basicWeek,basicDay'
                    },
                    displayEventEnd: {
                        month: true,
                        basicWeek: true,
                        "default": true
                    },
                    defaultDate: '2014-11-12',
                    //editable: true,
                    eventLimit: false, // allow "more" link when too many events
    
                    events: 
                    "<?php echo base_url('admin/schedule/scheduledetails/hel/');?>"+"/"+packageid,
                }); 
    
            $('#packageid').change(function() { //any select change on the dropdown with id country trigger this code           
            var packageid = $('#packageid').val();
                alert(packageid);
            if( packageid != null ) {
                $('#calendar').fullCalendar('addEventSource', '/admin/schedule/scheduledetails/hel/'+packageid);
            }
    
        }
    
    
            });
        });
    
    </script>
    
  • 0

    以下是我使用FullCalendar实现过滤的方法 . 使用下拉菜单触发事件 . 初始视图显示所有事件 . 使用下拉菜单会触发过滤器 . 过滤器可以保存月,周和日视图 .

    $(document).ready(function() {
    
        $('#calendar').fullCalendar({
            header: {
                left: 'prev,next today',
                center: 'title',
                right: 'month,basicWeek,basicDay'
            },
            defaultDate: (new Date()).toISOString().substring(0, 10),
            navLinks: true, // can click day/week names to navigate views
            editable: true,
            eventLimit: true, // allow "more" link when too many events
            events: 'include/myfeed.php'
        });
    
    });
    
    function filterByDealer(dealer){
        $('#calendar').fullCalendar('removeEvents');
        $('#calendar').fullCalendar('addEventSource','include/myfeed.php?d='+dealer);
    }
    

相关问题