从Angular Controller

时间:2015-04-22 12:55:41

标签: angularjs twitter-bootstrap-3 modal-dialog bootstrap-modal angularjs-ng-click

我试图弄清楚如何从Angular控制器中呈现一个bootstrap模态对话框。基本上我所拥有的是一张桌子。当用户单击表格行时,我想要提供一个模态对话框,其中包含有关所选行的详细信息。

我考虑接近这一点的方法是让每个表行响应ng-click。 ng-click将调用控制器中的一个函数,该函数将显示模态对话框,并将所需的数据传递给它。

我知道如何从视图本身显示模态对话框,但我不确定如何从控制器触发模态。有什么想法吗?

对于视图,控制器具有以下功能,当用户选择行来查看模式对话框时,将调用该功能。

$scope.rowClicked = function(rowID){
    $scope.dataForModal = Data.get(rowID, function(err,data){
        //Here is where I'd like to display the modal dialog in the view
    });
}

1 个答案:

答案 0 :(得分:3)

请参阅http://angular-ui.github.io/bootstrap/#/modal

在视图中的单元格/行上使用ng-click="showDetails(item)"。然后在控制器中使用此代码来显示模态:

$scope.showDetails = function (item) {
    var modalInstance = $modal.open({
        templateUrl: 'yourview.html',
        controller: 'DetailModalController',                       
        resolve: {
            item: function () {
                return  item;
            },                            
        }
    });

    modalInstance.result.then(function (item) {
        // ok
    }, function () {
        // dismiss
    });
};

您的模态控制器可以是这样的:

angular.module('app').controller('DetailModalController', [
    '$scope', '$modalInstance', 'item',
    function ($scope, $modalInstance, item) {

        $scope.item = item;

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

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

使用$modalInstance.close($scope.item);,您可以传递一个对象。使用$modalInstance.dismiss();,您可以在没有对象的情况下关闭模态。