gpt4 book ai didi

angularjs - 按 ESC 时检测 $mdDialog 关闭

转载 作者:行者123 更新时间:2023-12-04 21:08:52 25 4
gpt4 key购买 nike

我有一个带有输入字段的 $mdDialog 。在关闭 $mdDialog 之前,输入字段的内容被保存。因此,当用户按下“关闭”按钮时,会调用一个函数来对数据执行一些操作并保存它们。但是,我无法在 ESC 上检测到 $mdDialog 的关闭。是否可以在 $mdDialog Controller 中使用 ESC 检测关闭事件?

这是示例代码。
Codepen link

angular.module('MyApp', ['ngMaterial'])

.controller('AppCtrl', function($scope, $mdDialog, $rootScope) {
//$rootScope is used only of this demo
$rootScope.draft = ' ';

$scope.showDialog = function(ev) {
var msgDialog = $mdDialog.show({
controller: 'DemoDialogCtrl',
template: "<md-input-container><label>Text</label><input type='text' ng-model='myText' placeholder='Write text here.'></md-input-container><md-button ng-click='close()'>Close</md-button>",
})

};


});

(function() {
angular
.module('MyApp')
.controller('DemoDialogCtrl', DemoDialogCtrl);

DemoDialogCtrl.$inject = ['$scope', '$rootScope', '$mdDialog'];

function DemoDialogCtrl($scope, $rootScope, $mdDialog) {


$scope.close = function() {
//$rootScope is used only of this demo
// In real code, there are some other operations
$rootScope.draft = $scope.myText;

$mdDialog.hide();
}

}
})();
<div ng-controller="AppCtrl" class="md-padding dialogdemoBasicUsage" id="popupContainer" ng-cloak="" ng-app="MyApp">
<div class="dialog-demo-content" layout="row" layout-wrap="" layout-margin="" layout-align="center">
<md-button class="md-primary md-raised" ng-click="showDialog($event)">
Open Dialog
</md-button>
<div id="status">
<p>(Text written in $mdDialog text field must appear here when user closes the $mddialog. User can press close button or press ESC button.
</p>
<b layout="row" layout-align="center center" class="md-padding">
Draft: {{draft}}
</b>
</div>
</div>
</div>

最佳答案

你应该使用promise api。

$mdDialog.show().finally(
function onModalClose(){

}
);

但是带有外部代码的接收器应该与其他机制一起使用,例如通过提供范围。
var modalScope = $rootScope.$new(true);
$mdDialog.show({scope: modalScope}).finally(function(){
$rootScope.draft = modalScope.myText;
});

关于angularjs - 按 ESC 时检测 $mdDialog 关闭,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39354886/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com