Ceci est une démo très simplifiée de l'animation ng-class
en utilisant la transition que j'essaie d'atteindre. J'essaye de créer une animation de fondu simple quand un article est sélectionné.Pourquoi la transition ng-animate ng-class ne fonctionne-t-elle pas?
La sélection d'un élément ajoutera une classe selected
à l'aide de la directive ng-class
. J'essaye d'ajouter une transition après le documentation avec les classes de hook d'animation ajoutées par ng-animate
.
Voici le code que j'ai jusqu'ici. Il définit le opacity
à 0
avec la propriété de transition, et lorsque la classe .selected-add-active
est ajoutée, elle est supposée passer à opacity
1. Mais cela ne fonctionne pas.
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>
Pourquoi mon code de travail?