来自控制器调用的AngularJS Trigger指令

时间:2014-01-31 10:50:31

标签: angularjs angularjs-directive

我想触发一个包含jQuery指令的AngularJS自定义指令。怎么做到呢?我已经阅读了指令中的emit函数?

想法?

1 个答案:

答案 0 :(得分:24)

您可以使用服务在控制器和指令之间进行通信。

服务可能如下所示:

app.service("directiveService", function() {
    var listeners = [];
    return {
        subscribe: function(callback) {
            listeners.push(callback);
        },
        publish: function(msg) {
            angular.forEach(listeners, function(value, key) {
                value(msg);
            });
        }
    };
});

指令可以响应服务:

app.directive("jQueryDirective", function(directiveService) {
    directiveService.subscribe(function(msg) {
        // pretend this is jQuery 
        document.getElementById("example")
        .innerHTML = msg;
    });
    return {
        restrict: 'E'        
    };
});

只需替换我为jQuery操作所做的操作,你应该得到你需要的东西。

这是一个工作小提琴:http://jsfiddle.net/jeremylikness/wqXYx/