0

我希望“MyController2”继承“MyController1”,但是,两个控制器都是使用 ocLazyLoad 进行延迟加载的。根据Jussi Kosune n 对这个问题的回答(https://stackoverflow.com/a/15292441/2197555),我已经创建了一个registerDynamic()注册控制器的功能,但它仍然在“$controller”行报告以下错误在 controller1.js 中:

错误:[$injector:unpr] 未知提供者:$elementProvider <- $element <- DataTableController

我的代码是这样的。

第一个文件controller1.js

angular.module( 'myApp',[])
    .controller( 'MyController1', [ function($scope){
        // ...
    }]);

第二个文件controller2.js

angular.module( 'myApp')
    .controller( 'MyController2', [ '$controller', '$scope',function($controller, $scope){
         $controller('MyController1', {$scope: $scope }); // here triggers error '[$injector:unpr] Unknown provider'
         // ...
    }]);

在第三个 Filelazy-load.js中,我懒加载了上面的两个 .js 文件:

var app = angular.module('myApp'),
queueLen = app._invokeQueue.length;
app.directive( 'LazyLoad', [ function( ){
    return {
        restrict: 'EA',
        scope: {
           src: '@',
        },
        link: function( scope, element, attr ){
            var registerDynamic = function() {
                // Register the controls/directives/services we just loaded
                var queue = syncreonApp._invokeQueue;
                for(var i=queueLen;i<queue.length;i++) {
                    var call = queue[i];
                    // call is in the form [providerName, providerFunc, providerArguments]
                    var provider = syncreonApp.providers[call[0]];
                    if(provider) {
                        // e.g. $controllerProvider.register("Ctrl", function() { ... })
                        $log.debug("Registering " + call[1] + " " + call[2][0] + " ...");
                        provider[call[1]].apply(provider, call[2]);
                    }
                }
                queueLen = i;
            },
            loadMultipleJs = function ( js_files ){
                var deferred = $q.defer();
                var js_file1 = js_files.shift(),
                    js_file2 = js_files.shift();

                 $ocLazyLoad.load( js_file1 )
                    .then ( function(){
                        registerDynamic();
                        $ocLazyLoad.load( js_file2 )
                            .then ( function(){
                                registerDynamic();
                                deferred.resolve();
                            }, function(){
                                deferred.reject();
                            });
                    }, function(){
                        deferred.reject();
                    });
           };
           jsonOfJsFilesToLoad = JSON.parse(scope.src);
           loadMultipleJs(jsonOfJsFilesToLoad );
       }
   };
}]);

更新

“未知提供者”错误的官方 Angular 文档说:

尝试将一个控制器注入另一个控制器也会引发 Unknown provider 错误:

也许即使使用 $controller 服务,我们也无法将控制器注入花药?

4

1 回答 1

1

您将错误消息脱离上下文。

尝试将一个控制器注入另一个控制器也会引发 Unknown provider 错误:

angular.module('myModule', [])
   .controller('MyFirstController', function() { /* ... */ })
   .controller('MySecondController', ['MyFirstController', function(MyFirstController) {
     // This controller throws an unknown provider error because
     // MyFirstController cannot be injected.
   }]);

这不是您实例化控制器的方式。

它具体说:

如果您想自己实例化控制器,请使用 $controller 服务。

这是您实例化控制器的方式

在别处寻找你的问题。

您的错误信息:

未知提供者:$elementProvider <- $element <- DataTableController

我读这篇文章的方式是,在您的 中DataTableController,您正在尝试注入$element. $element不是服务是本地的。使用服务$element作为本地人注入$controller

$controller('DataTableController', {$scope: $scope, $element: value });
于 2016-01-29T18:16:18.857 回答