在我的应用中,我想在加载过程中显示加载指示。我已经成功实现了这个:
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();
}
});
};
}]);
Plunker:http://plnkr.co/edit/L6opqA?p=preview
但是,我认为我在添加和删除类时复制了大量的ngAnimate代码,并使用硬编码超时对content-loaded
的删除进行了硬编码。
是否可以将我的示例转换为使用较少重复代码的ngAnimate?
我自己很难理解这一点,因为关于ngAnimate的文档并没有关注JS触发的动画。
小注释没有反映在plunker中:我必须在加载期间渲染元素的子元素,因为该元素包含一个调用$.width
的jQuery插件,对于未呈现的元素将返回0。
答案 0 :(得分:1)
我发现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;
}