所以我正在尝试应用一些漂亮的动画,它们工作得很好,但不是很多,因为它们会破坏布局。
问题是我需要position: absolute
在动画时使用,以便我可以使用transform
,如下所示:
export function SlideLeft() {
return trigger('slideLeft', [
state('void', style({position: 'absolute', width: '100%', transform: 'translate3d(100%, 0, 0)'}) ),
state('*', style({position: 'absolute', width: '100%', transform: 'translate3d(0, 0, 0)'}) ),
transition(':enter', [
style({transform: 'translate3d(100%, 0, 0)'}),
animate('400ms ease', style({transform: 'translate3d(0, 0, 0)'}))
]),
transition(':leave', [
style({transform: 'translate3d(0, 0, 0)'}),
animate('400ms ease', style({transform: 'translate3d(100%, 0, 0)'}))
])
]);
}
用法:
@Component({
animation: [SlideLeft()]
})
export class SomeComponent {
@HostBinding('@slideLeft') value = '';
}
虽然这可行,但它会在动画完成时破坏元素高度,因为组件不再是页面流的一部分。
相反,我想做的是像上面那样制作动画,但是当动画完成后,我想删除该position: absolute
位。
我以为我可以通过position: absolute
从void
and*
样式对象中删除来实现这一点,但这只会导致动画完全中断。
是否有可能实现我想要的,如果是,我将如何去做?