AngularJS控制器:将公共代码移动到单独的文件

Eri*_*icC 8 angularjs

我有一些带有一些通用代码的控制器,特别$scope.$watch是对于几个控制器来说是相同的.如何将此代码放在单独的文件中,并在需要此功能的各种控制器中导入公共代码$watch

Bra*_*lls 8

可以通过传入控制器的范围使用服务:

angular.module('app').service("CommonFunctions", ['SomeService', function(SomeService) {
    var commonFunctions = {};
    commonFunctions.init = function(scope){
        scope.$watch(function(){},function(){})
    };
    return commonFunctions;
}]);

angular.module('app').controller('Ctrl1', 
['$scope','CommonFunctions',function($scope,CommonFunctions) {
    CommonFunctions.init($scope);
}]);

angular.module('app').controller('Ctrl2', 
['$scope','CommonFunctions',function($scope,CommonFunctions) {
    CommonFunctions.init($scope);
}]);
Run Code Online (Sandbox Code Playgroud)

这样您就可以使用单个控制器的范围,但在服务中使用通用方法.angular.extend($scope, AService)如果您希望实际添加到控制器范围的服务的常用功能,您也可以在控制器中使用.

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

当然这很酷,但是你确定你不想使用$rootscope.$broadcast()吗?这写得很好:http://toddmotto.com/all-about-angulars-emit-broadcast-on-publish-subscribing/