2016-08-30 58 views
1

我想调用app.js文件中的控制器方法[getFacility()]。 但是当我用下面的代码段,我得到了错误,如如何从角度调用app.js中的控制器方法

Error: [$injector:unpr] Unknown provider:

这里我控制器文件和服务文件

app.js

... 
...  
.state('facilityHome.editFacility', 
{ 
    url: '/editFacility/:facilityId', 
    templateUrl: '/views/facility/newFacility.html', 
    controller: 
     function($scope, $stateParams, facilityController) { 
       facilityController.getFacility($stateParams.facilityId); 
     } 
} 

.... 
... 

facilityControlelr.js

app.controller('facilityController', 
['$scope', '$rootScope','$location','$filter', 'facilityService', 
    function ($scope, $rootScope,$location,$filter, facilityService){ 

     /* Assign Object */ 
     var facilityScope = this; 

     /* Initialize DTO Object */ 
     facilityScope.facilityDTO={ 
      id:null, 
      version:null, 
      facilityName:"", 
      description:"" 
     }; 


     /* Initialize Object Array */ 
     facilityScope.facilityList = []; 


     facilityScope.getFacility=function(id){ 
      facilityService.fetchFacility(id) 
       .then(
       function(successRespond) { 
        $scope.facilityDTO = successRespond; 
       }, 
       function(errResponse){ 
        console.error('Error while fetching'); 
        console.error(errResponse); 
       } 
      ); 

     }; 

    } 
]); 

这里我得到了我的控制台。

"Error: [$injector:unpr] Unknown provider: facilityControllerProvider <- facilityController http://errors.angularjs.org/1.5.0/ $injector/unpr?p0=facilityControllerProvider%20%3C-NaNacilityController minErr/<@https://ajax.googleapis.com/ajax/libs/angularjs/1.5.0/angular.js:68:12 createInjector/providerCache.$injector<@https://ajax.googleapis.com/ajax/libs/angularjs/1.5.0/angular.js:4397:19 [email protected]https://ajax.googleapis.com/ajax/libs/angularjs/1.5.0/angular.js:4550:39 createInjector/protoInstanceInjector<@https://ajax.googleapis.com/ajax/libs/angularjs/1.5.0/angular.js:4402:28 [email protected]https://ajax.googleapis.com/ajax/libs/angularjs/1.5.0/angular.js:4550:39 [email protected]https://ajax.googleapis.com/ajax/libs/angularjs/1.5.0/angular.js:4574:58 [email protected]https://ajax.googleapis.com/ajax/libs/angularjs/1.5.0/angular.js:4616:18 $ControllerProvider/this.$gethttps://ajax.googleapis.com/ajax/libs/angularjs/1.5.0/angular.js:9870:18 z/<.compile/<@https://cdnjs.cloudflare.com/ajax/libs/angular-ui-router/0.3.1/angular-ui-router.min.js:7:23873 [email protected]https://ajax.googleapis.com/ajax/libs/angularjs/1.5.0/angular.js:9492:9 [email protected]https://ajax.googleapis.com/ajax/libs/angularjs/1.5.0/angular.js:8978:11 [email protected]https://ajax.googleapis.com/ajax/libs/angularjs/1.5.0/angular.js:8226:13 [email protected]https://ajax.googleapis.com/ajax/libs/angularjs/1.5.0/angular.js:8106:30 compilationGenerator/<@https://ajax.googleapis.com/ajax/libs/angularjs/1.5.0/angular.js:8447:20 [email protected]https://cdnjs.cloudflare.com/ajax/libs/angular-ui-router/0.3.1/angular-ui-router.min.js:7:23072 y/l.compile/https://cdnjs.cloudflare.com/ajax/libs/angular-ui-router/0.3.1/angular-ui-router.min.js:7:23492 $RootScopeProvider/this.$gethttps://ajax.googleapis.com/ajax/libs/angularjs/1.5.0/angular.js:17143:15 v/y.transitionTo/y.transition<@https://cdnjs.cloudflare.com/ajax/libs/angular-ui-router/0.3.1/angular-ui-router.min.js:7:18793 [email protected]https://ajax.googleapis.com/ajax/libs/angularjs/1.5.0/angular.js:15552:28 scheduleProcessQueue/<@https://ajax.googleapis.com/ajax/libs/angularjs/1.5.0/angular.js:15568:27 $RootScopeProvider/this.$gethttps://ajax.googleapis.com/ajax/libs/angularjs/1.5.0/angular.js:16820:16 $RootScopeProvider/this.$gethttps://ajax.googleapis.com/ajax/libs/angularjs/1.5.0/angular.js:16636:15 $RootScopeProvider/this.$gethttps://ajax.googleapis.com/ajax/libs/angularjs/1.5.0/angular.js:16928:13 [email protected]https://ajax.googleapis.com/ajax/libs/angularjs/1.5.0/angular.js:11266:36 [email protected]https://ajax.googleapis.com/ajax/libs/angularjs/1.5.0/angular.js:11464:7 [email protected]https://ajax.googleapis.com/ajax/libs/angularjs/1.5.0/angular.js:11405:9

+0

为什么不在控制器中注入状态? –

+0

你可以创建plnkr吗? – krutkowski86

+0

你能解释一下,你想通过这段代码实现什么? –

回答

1

为了注射控制器到另一个控制器,使用$controller服务。

.state('facilityHome.editFacility', 
{ 
    url: '/editFacility/:facilityId', 
    templateUrl: '/views/facility/newFacility.html', 
    controller: 
     function($scope, $stateParams, $controller) { 
      var facCtrl = $controller("facilityController", {'$scope': $scope}); 
      facCtrl.getFacility($stateParams.facilityId); 
     } 
} 

因为facilityController manipuates $scope$scope需要被注入的本地。请参阅AngularJS $controller Service API Reference

-1

您不能在另一个控制器中注入控制器。你需要一个工厂/服务。

看到一些文档:https://docs.angularjs.org/guide/services

+0

如果是这样,我可以从'$ stateProvider.state'的内部调用控制器方法? – Sadun89

+0

你不能。您需要一项服务来共享控制器之间的数据/逻辑。 – vjarysta

+0

不能是不正确的..虽然它不建议。一个控制器可以注入另一个控制器。 – undefined

相关问题