ui bootstrap модальный контроллер 'не определен'

Я пытаюсь использовать модальную директиву из ui-bootstrap 0.6

вот рабочий плункер по умолчанию со страницы ui-bootstrap:

http://plnkr.co/edit/JGBiBSeRqOnwRhYA9py8?p=preview

Теперь я попытался сделать стиль кодирования подходящим для стиля angular-seed, чтобы включить его в одно приложение, например:

http://plnkr.co/edit/Y59rwlcNpQdijKtmjOPy?p=preview

angular.module('MyModal', ['ui.bootstrap', 'MyModal.controllers']);

angular.module('MyModal.controllers', [])
    .controller('ModalDemoCtrl', [ '$scope', '$modal', '$log', function ($scope, $modal, $log) {
    $scope.items = ['item1', 'item2', 'item3'];

    $scope.open = function () {
        var modalInstance = $modal.open({
            templateUrl: 'myModalContent.html',
            controller: ModalInstanceCtrl,
            resolve: {
                items: function () {
                return $scope.items;
                }
            }
        });

        modalInstance.result.then(function (selectedItem) {
            $scope.selected = selectedItem;
        }, function () {
            $log.info('Modal dismissed at: ' + new Date());
        });
    };
}])
.controller('ModalInstanceCtrl', [ '$scope', '$modalInstance', 'items', function ($scope, $modalInstance, items) {
    $scope.items = items;
    $scope.selected = {
        item: $scope.items[0]
    };

    $scope.ok = function () {
        $modalInstance.close($scope.selected.item);
    };

    $scope.cancel = function () {
        $modalInstance.dismiss('cancel');
    };
}]);

но выдает ошибку ReferenceError: ModalInstanceCtrl is not defined

как я могу заставить эту работу работать, используя такой способ определения контроллеров?


person François Romain    schedule 17.10.2013    source источник


Ответы (2)


Укажите имя контроллера как String, точно так же, как в определениях маршрутов, директивах и т. Д .:

var modalInstance = $modal.open({
        templateUrl: 'myModalContent.html',
        controller: 'ModalInstanceCtrl',
        resolve: {
            items: function () {
            return $scope.items;
            }
        }
    });
person pkozlowski.opensource    schedule 17.10.2013
comment
Спасибо! Потребовалось около 2 часов, чтобы понять, что это моя проблема. - person brutalhonesty; 18.03.2014
comment
Дерп, бинго. Это ошибка в документации, это тоже меня зациклило :( - person Jason Farnsworth; 03.04.2014
comment
Пробовал делать, вызывая контроллер по строке, не получается - person Chester Rivas; 06.02.2015

Вы можете использовать кавычки, как предлагает другой ответ, или вы также можете сделать это в качестве примера в документации и определить переменную:

var ModalInstanceCtrl = function ($scope, $modalInstance, items) { ... }

person Foo L    schedule 17.10.2013