控制器的angularjs缩小问题

前端之家收集整理的这篇文章主要介绍了控制器的angularjs缩小问题前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
这是我的控制器:

angular.module('domiciliations').controller('mandatsCtrl',['$scope','Domiciliation','logger',function ($scope,Domiciliation,logger) {
    $scope.mandats = Domiciliation.query();

    $scope.fullName = function () {
        return this.Person ? 'test' : 'test2'
    }

    $scope.isNextDisabled = function () {
        return false;
    }

    $scope.isPrevDisabled = function () {
        return true;
    }

    $scope.next = function () {
        logger.info("test");
    }
}]);

缩小时,我收到一个错误

Error: Unknown provider: nProvider <- n

现在,如果我在控制器之后包含以下行,那么它可以工作:

mandatsCtrl.$inject = ['$scope','logger'];

我认为在控制器函数中使用数组类型声明的重点是避免使用$inject ….我是否错过了什么?

解决方法

如果你要缩小控制器的JavaScript代码,它的所有函数参数也会缩小,并且依赖注入器将无法正确识别服务.
有两种方法可以处理角度的缩小

1)Just assign an array with service identifier strings into the $inject property of the controller function
 mandatsCtrl.$inject = ['$scope','logger'];

2) Using bracketnotation
var mandatsCtrl= ['$scope','logger' function($scope,$Domiciliation,logger) { /* constructor body */ }];

http://docs.angularjs.org/tutorial/step_05

猜你在找的Angularjs相关文章