我有一些奇怪的问题ng-class
,我怀疑它与比赛条件有关。ng级和动画的比赛条件
这里是plunker example
下面是相关的js代码
self.slideLeft = function() {
if (self.end_index < self.list_of_stuff.length) {
self.direction = 'left';
debugger;
self.start_index = self.start_index + 4;
self.end_index = self.end_index + 4;
self.display_list = self.list_of_stuff.slice(self.start_index, self.end_index);
}
}
self.slideRight = function() {
if (self.start_index > 0) {
self.direction = 'right';
debugger;
self.start_index = self.start_index - 4;
self.end_index = self.end_index - 4;
self.display_list = self.list_of_stuff.slice(self.start_index, self.end_index);
}
}
下面是相关的HTML
<div class="stuff-wrapper">
<div class="stuff"
ng-class="bCtrl.directionClass()"
ng-repeat="stuff in bCtrl.display_list">
{{stuff}}
</div>
</div>
这里是动画。
.left.ng-enter,
.left.ng-leave {
-webkit-transition: all 1s ease-in-out;
}
.left.ng-enter {
transition-delay: 0.7s;
opacity: 0;
left: 10%;
}
.left.ng-enter-active {
opacity: 1;
left: 0;
}
.left.ng-leave {
opacity: 1;
left: -10%;
}
.left.ng-leave-active {
left: -20%;
opacity: 0;
}
这是一个简单的应用程序,可以左右滑动数字列表。
如果按下左按钮,则数字向左滑动。
如果按下右键,则数字向右滑动。
但是我们看到,如果方向发生改变,数字将首先滑向错误的方向,随后的方向将是正确的。
我怀疑这是由于比赛条件。
的确,我看到ng-class
在我使用调试器改变方向self.direction
后没有得到应用。
这很好奇。
有没有办法解决这个问题?