【问题标题】:ui bootstrap modal's controller 'is not defined'ui bootstrap modal 的控制器'未定义'
【发布时间】:2013-10-17 16:45:22
【问题描述】:

我正在尝试使用 ui-bootstrap 0.6 中的模态指令

这是来自 ui-bootstrap 页面的工作默认 plunker:

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

如何使用这种定义控制器的方式来完成这项工作?

【问题讨论】:

    标签: angularjs angular-ui-bootstrap


    【解决方案1】:

    String 的形式提供控制器名称,就像在路由定义、指令等中所做的那样:

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

    【讨论】:

    • 谢谢!花了大约 2 个小时才弄清楚这是我的问题。
    • Derp,宾果游戏。这是文档中的错误,它也让我陷入了循环:(
    • 我试过了,通过字符串调用控制器,不行
    【解决方案2】:

    您可以按照其他答案的建议使用引号,也可以按照文档中的示例进行操作并定义变量:

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

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2017-07-25
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2016-01-08
      • 2020-03-04
      • 2016-01-03
      相关资源
      最近更新 更多