$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',         
        }
    }
})

$broadcast从当前作用域开始,向下到子作用域。

$emit从当前作用域开始,然后沿作用域链向上。

没有转到同级范围的事件调度方法。您需要$emit父级并在那里处理事件以将其$broadcast回去。

相关内容

  • 没有找到相关文章

最新更新