Heim >Web-Frontend >js-Tutorial >AngularJS-Popup-Modalbox (Modell)_AngularJS

AngularJS-Popup-Modalbox (Modell)_AngularJS

WBOY
WBOYOriginal
2016-05-16 15:06:101714Durchsuche

Empfohlene Lektüre: Detaillierte Erläuterung des modalen AngularJS-Dialogfelds

$modal ist ein Dienst, der schnell modale Fenster, Teilseiten und Controller erstellen und diese verknüpfen kann.

$modal hat nur eine offene Methode (Optionen)

templateUrl: die Adresse des modalen Fensters

Vorlage: Wird zur Anzeige von HTML-Tags verwendet

Bereich: Wird für Inhalte verwendet, deren Bereich modal ist (tatsächlich erstellt $modal einen untergeordneten Bereich des aktuellen Bereichs. Standardmäßig ist $rootScope
).

Controller: Der für $modal angegebene Controller initialisiert $scope und der Controller kann mit $modalInstance
injiziert werden

resolve: Definieren Sie ein Mitglied und übergeben Sie es an den durch $modal angegebenen Controller, was einem reslove-Attribut von Routen entspricht. Wenn Sie ein objec-Objekt übergeben müssen, müssen Sie angle.copy()
verwenden

Hintergrund: Steuern Sie den Hintergrund, zulässige Werte: true (Standard), false (kein Hintergrund), „statisch“ – der Hintergrund existiert, aber wenn Sie außerhalb des modalen Fensters klicken, wird das modale Fenster nicht geschlossen

Tastatur: Ob das modale Dialogfeld geschlossen wird, wenn Esc gedrückt wird. Der Standardwert ist true

windowClass: Geben Sie eine Klasse an und fügen Sie sie dem modalen Fenster hinzu

Die open-Methode gibt eine modale Instanz zurück, die die folgenden Eigenschaften hat

close(result): Schließt das modale Fenster und übergibt ein Ergebnis

dismiss(reason): Verwerfen Sie die modale Methode und übergeben Sie einen Grund

Ergebnis: Ein Vertrag wurde bestanden, als das modale Fenster geschlossen oder entlassen wurde

geöffnet: ein Vertrag, eine Variable, die übergeben wird, wenn das modale Fenster geöffnet und der Inhalt geladen wird

Darüber hinaus erweitert $modalInstance zwei Methoden $close(result) und $dismiss(reason). Diese Methoden ermöglichen ein einfaches Schließen des Fensters und erfordern keine zusätzlichen Controller

HTML

<!DOCTYPE html> 
<html ng-app="ModalDemo"> 
<head> 
<title></title> 
<link href="lib/bootstrap/css/bootstrap.min.css" rel="stylesheet"> 
<script src="lib/angular/angular.min.js"></script> 
<script src="lib/bootstrap-gh-pages/ui-bootstrap-tpls-...min.js"></script> 
<script src="lib/angular/in/angular-locale_zh-cn.js"></script> 
</head> 
<body> 
<div ng-controller="ModalDemoCtrl"> 
<script type="text/ng-template" id="myModalContent.html"> 
<div class="modal-header"> 
<h>I'm a modal!</h> 
</div> 
<div class="modal-body"> 
<ul> 
<li ng-repeat="item in items"> 
<a ng-click="selected.item = item">{{ item }}</a> 
</li> 
</ul> 
Selected: <b>{{ selected.item }}</b> 
</div> 
<div class="modal-footer"> 
<button class="btn btn-primary" ng-click="ok()">OK</button> 
<button class="btn btn-warning" ng-click="cancel()">Cancel</button> 
</div> 
</script> 
<button class="btn" ng-click="open()">Open me!</button> 
</div> 
<script> 
var ModalDemo = angular.module('ModalDemo', ['ui.bootstrap']); 
var ModalDemoCtrl = function ($scope, $modal, $log) { 
$scope.items = ['item', 'item', 'item']; 
$scope.open = function () { 
var modalInstance = $modal.open({ 
templateUrl: 'myModalContent.html', 
controller: ModalInstanceCtrl, 
resolve: { 
items: function () { 
return $scope.items; 
} 
} 
}); 
modalInstance.opened.then(function(){//模态窗口打开之后执行的函数 
console.log('modal is opened'); 
}); 
modalInstance.result.then(function (result) { 
console.log(result); 
}, function (reason) { 
console.log(reason);//点击空白区域,总会输出backdrop click,点击取消,则会暑促cancel 
$log.info('Modal dismissed at: ' + new Date()); 
}); 
}; 
}; 
var ModalInstanceCtrl = function ($scope, $modalInstance, items) { 
$scope.items = items; 
$scope.selected = { 
item: $scope.items[] 
}; 
$scope.ok = function () { 
$modalInstance.close($scope.selected); 
}; 
$scope.cancel = function () { 
$modalInstance.dismiss('cancel'); 
}; 
}; 
</script> 
</body> 
</html> 

Das Obige ist der relevante Inhalt der AngularJs-Popup-Modalbox (Modell), die Ihnen der Herausgeber vorgestellt hat. Ich hoffe, er wird für alle hilfreich sein!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn