如何使用ngAnimate在CSS类之间制作动画?

时间:2013-12-02 10:25:28

标签: javascript angularjs ng-animate

在我的应用中,我想在加载过程中显示加载指示。我已经成功实现了这个:

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。

1 个答案:

答案 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;
}