在我的应用中,我想在加载过程中显示加载指示。我已经成功实现了这一点:
lyr.ui.directive('loading', ['$timeout', function($timeout) {
return function(scope, element, attr) {
element.addClass('content-loading');
var unbind = scope.$watch(attr.loading, function(value) {
if (value) {
element.removeClass('content-loading');
element.addClass('content-loaded');
$timeout(function() {
element.removeClass('content-loaded');
}, 250);
unbind();
}
});
};
}]);
柱塞:http://plnkr.co/edit/L6opqA?p=preview
但是,我想我在添加和删除类以及使用硬编码超时对
content-loaded
的硬编码中复制了大量ngAnimate代码。是否可以将我的示例转换为使用ngAnimate且重复代码更少?
我自己很难弄清楚这一点,因为ngAnimate上的文档并不关注JS触发的动画。
需要注意的一点是,在插件中没有体现出这一点:我必须在加载期间渲染元素的子元素,因为该元素包含一个调用
$.width
的jQuery插件,对于未渲染的元素,该插件将返回0。 最佳答案
我发现another plunker向我展示了如何执行此操作。
解决方案:http://plnkr.co/edit/bzIReo?p=preview
myApp.directive('loading', ['$animate', function($animate) {
return function(scope, element, attr) {
element.addClass('content-loading');
var unbind = scope.$watch(attr.loading, function(value) {
if (value) {
$animate.removeClass(element, 'content-loading');
unbind();
}
});
};
}]);
CSS:
.content-loading {
background-image: url();
background-repeat: no-repeat;
background-position: 20px 10px;
}
.content-loading > * {
opacity: 0;
}
/* Class name generated by ngAnimate */
.content-loading-remove > * {
-webkit-transition: opacity 250ms linear;
-moz-transition: opacity 250ms linear;
transition: opacity 250ms linear;
opacity: 1;
}
关于javascript - 如何使用ngAnimate在CSS类之间设置动画?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/20325954/