Angular LAB:动画列表并使用 AnimationBuilder 实现命令式动画
文章标签
动画
您知道 angular 包含一个复杂的动画系统吗?当我想要在元素进入屏幕或被破坏时为其设置动画时,我发现它特别有用!
此外,您还可以使用 animationbuilder 来强制播放、暂停或停止一些自定义动画!让我们看看它是如何完成的。
创建列表
在本练习中,我们首先创建一个列表,如下所示:
@component({ selector: 'app-root', standalone: true, template: ` <button>add user</button>
请注意,我们添加了一个将用户添加到列表中的按钮!
动画列表
现在,如果我们想要为要添加的新用户设置动画该怎么办?首先,我们想通过在主配置中提供它来告诉 angular 我们想要使用它的动画系统:
import { provideanimationsasync } from '@angular/platform-browser/animations/async';bootstrapapplication(appcomponent, { providers: [ provideanimationsasync(), ]});
然后,我们可以创建我们的动画:
import { trigger, transition, style, animate } from '@angular/animations';const fadeinanimation = trigger('fadein', [ transition(':enter', [ style({ transform: 'scale(0.5)', opacity: 0 }), animate( '.3s cubic-bezier(.8, -0.6, 0.2, 1.5)', style({ transform: 'scale(1)', opacity: 1 }) ) ])])
有了这些帮助者,我们: