Angular动画第一次能正常运行,但不会在后续调用中运行。
创始人
2024-10-24 13:01:39
0

这可能是由于使用了changeDetection策略'OnPush”的组件导致的。在这种情况下,动画只会在组件输入发生更改时重新计算,并在此基础上运行。因此,如果组件未检测到输入更改,则动画将不再运行。

要解决这个问题,请确保在组件中更改了输入,以通知Angular启动动画。您可以使用RxJs的行为主题来进行此操作。例如,您可以在组件中添加以下内容:

import { Component, OnInit, Input, ChangeDetectionStrategy } from '@angular/core'; import { BehaviorSubject } from 'rxjs';

@Component({ selector: 'app-my-component', templateUrl: './my-component.component.html', styleUrls: ['./my-component.component.css'], changeDetection: ChangeDetectionStrategy.OnPush }) export class MyComponentComponent implements OnInit { @Input() data: any; animationSubject = new BehaviorSubject(false);

constructor() { }

ngOnInit() { }

ngAfterViewInit() { this.animationSubject.next(true); }

triggerAnimation() { this.animationSubject.next(false); setTimeout(() => { this.animationSubject.next(true); }, 0); } }

此代码利用了RxJs的行为主题,每次更改数据输入时都会通知更改检测。此外,在调用动画时,我们将先将主题设置为false,然后立即将其重置为true以重新计算动画。

相关内容

热门资讯

第八分钟辅助!hhpoker哪... 第八分钟辅助!hhpoker哪个俱乐部靠谱,约局吧作弊脚本,法子教程(有挂助手)运hhpoker哪个...
三分钟辅助!约局吧怎么看有没有... 三分钟辅助!约局吧怎么看有没有挂,wpk辅助器是真的吗,技法教程(有人有挂)1、约局吧怎么看有没有挂...
9分钟辅助!菠萝辅助器免费版的... 9分钟辅助!菠萝辅助器免费版的功能介绍,hhpkoer辅助器,手段教程(有挂秘籍)1、菠萝辅助器免费...
第七分钟辅助!拱趴大菠萝有什么... 第七分钟辅助!拱趴大菠萝有什么挂,wepoker辅助工具,法子教程(有挂技巧)1、不需要AI权限,帮...
第十分钟辅助!wepoker究... 第十分钟辅助!wepoker究竟有没有透视,wepoker网页版透视方法,讲义教程(有挂实锤)1)w...
第三分钟辅助!pokemmo手... 第三分钟辅助!pokemmo手机辅助软件,wepoker公共底牌,模板教程(有挂方式)所有人都在同一...
五分钟辅助!wepoker脚本... 五分钟辅助!wepoker脚本,wepoker究竟有没有透视,指引教程(有挂教学)wepoker究竟...
第八分钟辅助!wepoker俱... 第八分钟辅助!wepoker俱乐部辅助器,约局吧德州真的存在透视吗,办法教程(存在有挂)约局吧德州真...
第8分钟辅助!线上德州的辅助器... 第8分钟辅助!线上德州的辅助器是什么,wpk辅助购买,阶段教程(有挂方式)1、不需要AI权限,帮助你...
第一分钟辅助!wepoker私... 第一分钟辅助!wepoker私人局有透视吗,wpk有那种辅助吗,策略教程(有挂详情)1、让任何用户在...