Animationen mit ng-animate in AngularJS 1.2
angularjs | Sascha Brink • | 4 Minuten
Seit AngularJS 1.2 sind Animationen mit ng-animate
fester Bestandteil des Frameworks. Unterstützt werden Animationen mit CSS3 und JavaScript.
Installation
Die Unterstützung für Animationen befindet sich in einer separaten Datei. Der erste Schritt besteht darin, diese einzubinden und das Modul ngAnimate
als Abhängigkeit anzugeben. In eurer HTML-Datei wäre das beispielsweise für die AngularJS-Version des Google-CDN:
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.22/angular.js"></script>
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.22/angular-animate.js"></script>
Dazu die Modul-Deklaration im JavaScript:
angular.module('myApp', ['ngAnimate'])
Direktiven und Ereignisse
AngularJS unterstützt Animationen für die folgenden Direktiven:
Direktive | Unterstützte Animationen |
---|---|
ngRepeat | enter, leave and move |
ngView | enter and leave |
ngInclude | enter and leave |
ngSwitch | enter and leave |
ngIf | enter and leave |
ngClass | add and remove |
ngShow & ngHide | add and remove |
Von jeder Direktive können verschiedene Ereignisse animiert werden. Für ngRepeat
sind es zum Beispiel:
- enter: ein neues Element wird in die Liste eingefügt
- leave: ein Element wird aus der Liste entfernt
- move: ein bestehendes Element wird innerhalb der Liste verschoben
Vorbereitung im HTML
Der erste Schritt besteht immer darin, dem Element mit der Direktive eine Klasse zu geben. Dies gilt sowohl für Animation mit CSS3 als auch für Javascript.
<li ng-repeat="item in items" class="list-item">{{item}}</li>
Ab jetzt kommt es darauf an, ob ihr CSS oder JavaScript unterstützen wollt.
CSS3-Animationen
Beginnen wir mit der einfachen Variante - CSS3-Animationen. Wir animieren im folgenden Beispiel das Einblenden eines neuen Elements über einen Highlight-Effekt. D.h. ein neues Element leuchtet erst gelb auf und geht dann sanft in weiß über. In Eurem CSS schreibt ihr dazu:
.list-item.ng-enter {
-webkit-transition: 0.5s linear all;
transition: 0.5s linear all;
background-color: yellow;
}
.list-item.ng-enter-active {
background-color: white;
}
Der Ablauf dabei sieht folgendermaßen aus:
- Die Klasse
.ng-enter
wird als erstes hinzugefügt. - Es folgt unmittelbar die Klasse
.ng-enter-active
. - Es wird gewartet bis die Animation durchgelaufen ist.
- Beide Klassen werden wieder entfernt.
Die Namen der zusätzlichen CSS-Klassen kommen über Konvention zustande:
-
enter:
.ng-enter
und.ng-enter-active
-
leave:
.ng-leave
und.ng-leave-active
-
move:
.ng-move
und.ng-move-active
JavaScript-Animationen
Für die meisten Animationen reichen CSS3-Transitionen aus. Früher oder später werdet ihr aber wahrscheinlich an deren Grenzen stoßen. Entweder müsst ihr ältere Browser unterstützen oder ihr habt komplexe Animationen, die mit CSS3 nicht möglich sind.
Für Animationen mit JavaScript müsst ihr eine animation
mit dem Klassennamen auf eurem Modul definieren. Achtet dabei auf den Punkt im Namen!
Grundsätzlicher Aufbau einer Animation mit JavaScript:
angular.module('myApp', ['ngAnimate'])
.animation('.list-item', function() {
return {
enter/leave/move: function(element, done) {
// Die eigentliche Animation wird hier gestartet.
// done() muss nach Beenden aufgerufen werden
},
// Animation, die vor Hinzufügen/Entfernen der Klassen
// ausgeführt werden soll
beforeAddClass: function(element, className, done) { },
beforeRemoveClass: function(element, className, done) { },
// Animation, die nach Hinzufügen/Entfernen der Klassen
// ausgeführt werden soll
addClass: function(element, className, done) { },
removeClass: function(element, className, done) { }
};
});
Bei JavaScript-Animationen müsst ihr euch selbst um das richtige Timing der Animationen kümmern und nach dem Ende die Funktion done()
aufrufen.
Fazit
Seit Version 1.1.5 hat sich die Animations-API noch einmal komplett geändert - zum Besseren. Sobald das ‘ngAnimate’-Modul eingebunden wurde, ist die Bedienung kinderleicht. Zudem lassen sich Animationen sehr einfach später nachrüsten.
Inhaltsverzeichnis
Um alle Neuigkeiten zu erfahren, abonniere hier unseren Newsletter!
Newsletter abonnierenSascha Brink
Sascha betreut regelmäßig Angular-Projekte und unterstützt Firmen bei der Ausbildung ihrer Mitarbeiter. Im Jahr 2013 hat er die Platform AngularJS.DE gestartet um das Framework in Deutschland bekannter zu machen. Sascha gibt Angular- und JavaScript-Schulungen auf deutsch und englisch.