Javascript 延迟从关闭开始
我正在使用Javascript 延迟从关闭开始,javascript,angularjs,angular-ui,angular-ui-bootstrap,Javascript,Angularjs,Angular Ui,Angular Ui Bootstrap,我正在使用angularjs和angular ui库(特别是angular ui引导程序one) 如何延迟模式关闭?用户单击x或“取消”按钮后,我需要模态多显示半秒钟,但我还没有找到方法 我想在回调函数中添加一些超时,该函数被传递到modal实例的then函数中,例如: modalInstance.result.then(function success(){ // timeout .5 second }, function cancel() { // timeout .5 sec
angularjs
和angular ui
库(特别是angular ui引导程序
one)
如何延迟模式关闭?用户单击x
或“取消”按钮后,我需要模态多显示半秒钟,但我还没有找到方法
我想在回调函数中添加一些超时,该函数被传递到modal实例的then
函数中,例如:
modalInstance.result.then(function success(){
// timeout .5 second
}, function cancel() {
// timeout .5 second
});
但是回调函数中的代码实际上是在模式关闭后运行的。有办法做到这一点吗?您可以使用
$timeout(function() {
$modalInstance.dismiss('cancel');
}, 500);
使用单独的模态控制器完成代码:-
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);
};
});
您使用什么代码来关闭模式?还有,为什么你想让模态停留更长时间?我没有使用任何代码来关闭模态,只是默认的内置。原因是为了避免一些闪烁效果(如果我打开一个模式,关闭它,就会弹出另一个模式)。谢谢你的大力支持,我不知道我可以覆盖取消功能。您是否介意编辑您的答案,使其包含整个控制器?供日后参考。谢谢