$ broadcast仅在使用有限字符时触发

时间:2018-03-05 17:16:21

标签: javascript angularjs controller angular-broadcast

尝试使用Angular的$broadcast,当我测试它并使用字符串'hi',并在兄弟控制器中观察它时,它工作正常,如下所示:

//first controller
app.controller('colourKeyCtrl', colourKeyCtrl);
function colourKeyCtrl($scope, $timeout, patents, patentPhasesService) {
    vm.$onInit = function() {
       $scope.$broadcast('hi');
    }
}

//second controller
app.controller('graphDonutCtrl', graphDonutCtrl);
function graphDonutCtrl($scope, patents, patentPhasesService, $timeout) {
    $scope.$on('hi', function(event, opt){
       alert('hello there')
    })    
}

只要将字符串更改为其他任何内容(例如phaseChange),就无法在第二个控制器中调用$on方法。不知道为什么。我试图将$broadcast包裹在$timeout方法中,但尚未解决问题。

问题

我是以错误的方式使用$broadcast还是我的语法不正确?

.state('dashboard', {
    url: '/dashboard',
    views: {
        '@': {
            templateUrl: 'p3sweb/app/components/dashboard/views/dashboard.htm',
            controller: 'dashboardCtrl',
            controllerAs: '$ctrl'
        },
        'colourkeywidget@dashboard': {
            templateUrl: 'p3sweb/app/components/dashboard/views/ui-views/colour-key-widget.htm',
            controller: 'colourKeyCtrl',
            controllerAs: '$ctrl'                
        },
        'graphdonutwidget@dashboard': {
            controller: 'graphDonutCtrl',
            controllerAs: '$ctrl',                
            templateUrl: 'p3sweb/app/components/dashboard/views/ui-views/graph-donut-widget.htm',         
        }
    }
})

1 个答案:

答案 0 :(得分:1)

$broadcast从当前范围开始,然后转到子范围。

$emit从当前范围开始,然后向范围链上移。

没有事件调度方法进入兄弟范围。您需要$emit直到父母并处理事件到$broadcast它。