Dies ist eine stark vereinfachte Demo von ng-class
Animation mit Übergang, die ich versuche zu erreichen.Warum funktioniert der auf der ng-Klasse basierende ng-animate-Übergang nicht?
Ich versuche, eine einfache Einblendung Animation zu erstellen, wenn ein Element ausgewählt ist.
Bei Auswahl eines Elements wird eine selected
-Klasse mit der ng-class
-Direktive hinzugefügt. Ich versuche, einen Übergang dazu hinzuzufügen, der dem documentation mit den Animationshakenklassen folgt, die durch ng-animate
hinzugefügt werden.
Unten ist der Code, den ich bisher habe. Es setzt die opacity
zu 0
zusammen mit der Übergangseigenschaft, und wenn die .selected-add-active
Klasse hinzugefügt wird, soll es zu opacity
übergehen 1. Aber es funktioniert nicht.
angular.module('demo', ['ngAnimate'])
.controller('demoCtrl', function($scope) {
$scope.selected = false;
$scope.selectToggle = function() {
$scope.selected = !$scope.selected;
};
});
.item {
width: 50px;
height: 50px;
background: grey;
}
.item.selected {
background-color: dodgerblue;
}
.item.selected.selected-add {
transition: opacity 3s;
opacity: 0;
}
.item.selected.selected-add.selected-add-active {
opacity: 1;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/angular.js/1.5.7/angular.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/angular.js/1.5.7/angular-animate.js"></script>
<div ng-app="demo" ng-controller="demoCtrl">
<div class="item" ng-class="{selected:selected}"></div>
<br>
<br>
<button ng-click="selectToggle();">
{{selected? 'Unselect' : 'Select'}}
</button>
</div>
Warum funktioniert mein Code nicht?