Это сильно упрощенная демонстрация анимации ng-class
с использованием перехода, которую я пытаюсь реализовать.
Я пытаюсь создать простую анимацию затухания при выборе элемента.
Выбор элемента добавит к нему класс selected
с помощью директивы ng-class
. Я пытаюсь добавить к нему переход, следуя документации с классами хуков анимации, добавленными ng-animate
.
Ниже приведен код, который у меня есть до сих пор. Он устанавливает opacity
в 0
вместе со свойством перехода, и когда добавляется класс .selected-add-active
, предполагается переход в opacity
1. Но это не работает.
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>
Почему мой код не работает?