【问题标题】:Delay angular-ui modal from closing延迟 angular-ui 模态关闭
【发布时间】:2015-03-09 17:53:16
【问题描述】:

我将angularjsangular-ui 库一起使用(特别是angular-ui-bootstrap 之一)。

如何延迟模式关闭?在用户单击x 或取消按钮后,我需要让模态框多显示半秒,但我还没有找到方法。

我在考虑在回调函数中添加一些超时,传递给模态实例的then函数,例如:

modalInstance.result.then(function success(){
    // timeout .5 second
}, function cancel() {
   // timeout .5 second
});

但回调函数中的代码实际上是在模态关闭后运行的。有没有办法做到这一点?

【问题讨论】:

  • 你用什么代码来关闭模式?另外,为什么要让模态保持更长时间?
  • 我没有使用任何代码来关闭模式,只是默认的内置。原因是为了避免一些闪烁效果(如果我打开一个模式,关闭它并弹出另一个)。

标签: javascript angularjs angular-ui angular-ui-bootstrap


【解决方案1】:

你可以使用

 $timeout(function() {
     $modalInstance.dismiss('cancel');
 }, 500);

Plunker

带有单独的模态控制器的完整代码:-

angular.module('ui.bootstrap.demo', ['ui.bootstrap']);
angular.module('ui.bootstrap.demo').controller('ModalDemoCtrl', function ($scope, $modal, $log) {

  $scope.items = ['item1', 'item2', 'item3'];

  $scope.open = function (size) {

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

    modalInstance.result.then(function (selectedItem) {
      $scope.selected = selectedItem;
    }, function () {
      $log.info('Modal dismissed at: ' + new Date());
    });
  };
});

// Please note that $modalInstance represents a modal window (instance) dependency.
// It is not the same as the $modal service used above.

angular.module('ui.bootstrap.demo').controller('ModalInstanceCtrl', function ($scope, $modalInstance,$timeout, items) {

  $scope.items = items;
  $scope.selected = {
    item: $scope.items[0]
  };

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

  $scope.cancel = function () {
    $timeout(function() {
            $modalInstance.dismiss('cancel');
        }, 500);

  };
});

【讨论】:

  • 感谢 plunker,我不知道我可以覆盖取消功能。您介意编辑您的答案,使其包含整个控制器吗?备查。谢谢