javascript - angularjs fullcalendar eventclick范围

标签 javascript jquery angularjs angularjs-scope fullcalendar

我有一个名为 CalendarDemoCtrl 的 Controller ,其中我有完整日历的配置,如下所示。

$scope.uiConfig = {
        calendar: {
            height: 600,
            editable: false,
            locale:'es',
            //navLinks: true, // can click day/week names to navigate views
            businessHours: true, // display business hours
            allDaySlot: false,
            slotLabelFormat : 'h:mm a',
            timeFormat: 'h:mm a',
            navLinks: true,
            navLinkDayClick: function(date, jsEvent) {
                cc['mycalendar'].fullCalendar('changeView','agendaDay');
                cc['mycalendar'].fullCalendar('gotoDate',date);
                $scope.currentDate = cc['mycalendar'].fullCalendar("getView").title;
           },

            defaultView: 'agendaDay',
            slotDuration: '00:15:00',
            header: false,  // remove default toolbar
            //editable: true,   
            eventRender: $scope.eventRender,
            eventClick : $scope.onEventClick
            //dayClick : $scope.onEventClick
        }
    }

在同一个 Controller 中,我定义了 $scope.onEventClick 和 $scope.addEvent。

$scope.addEvent = function() {

        $rootScope.oldFormData = $.extend( true, {}, $scope.formData );

        $scope.entroModal = true;
        $scope.modalOpen('new');
    };
$scope.onEventClick = function(index) {


        $scope.formData = $.extend( true, {}, index.cita );
        var date_inicio = new Date(index.cita.inicio) ;
        $scope.formData.inicio = date_inicio.getDate() + "/" + ( date_inicio.getMonth() + 1) + "/"+ date_inicio.getFullYear()+ " " + date_inicio.getHours()+ ":" + (date_inicio.getMinutes()<10?'0':'') + date_inicio.getMinutes();
        var date_fin = new Date(index.cita.fin) ;
        $scope.formData.fin = date_fin.getDate() + "/" + ( date_fin.getMonth() + 1) + "/"+ date_fin.getFullYear()+ " " + date_fin.getHours()+ ":" + (date_fin.getMinutes()<10?'0':'') + date_fin.getMinutes();
        $.extend( $scope.formData , $rootScope.oldFormData );
        $scope.modalOpen('edit');
    };

当用户想要添加事件时,第一个与按钮一起使用,第二个用于编辑日历中的事件。但是,当添加事件时,范围会转到低于 eventclick 的范围,因此当我添加事件时,当我单击并编辑事件时,它会显示在日历中,该事件不会在日历中修改,因为它是上面的范围。

  1. $rootscope:id 1

  2. $scope:id 10(这是 eventclick 的作品)

  3. child $scope:id 11(这是 addevent 的作品)

这完全是一团糟,我很困惑这是如何发生的以及如何让这两个事件处于同一范围内?请指教谢谢!

最佳答案

我仍然不确定为什么会发生这种情况以及如何永久修复它,但我的解决方法是广播一个事件并确保在收听它时,它具有相同的范围。

关于javascript - angularjs fullcalendar eventclick范围,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40917943/

相关文章:

javascript - angular for each 如何为每个子对象添加属性

javascript - 如何控制 Angular 转换以避免看到内容加载

javascript - 使用 ng-repeat AngularJS 对数组中的项目进行计数

javascript函数-在引号内使用参数?

jquery - 检查选择器是否存在的最佳方法是什么?

javascript - 使用Javascript更改HTML页面但保持路径不变

javascript - 创建一个小型 jQuery 插件

javascript - DataTable 1.10x jQuery 列过滤器通过输入文本框服务器端

javascript - 保持上一页的类别

javascript - 无法在 appendchild 之后将表行与标题对齐