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以重新计算动画。

相关内容

热门资讯

透视软件!wepoker透视挂... 您好,wepoker数据分析工具这款游戏可以开挂的,确实是有挂的,需要了解加去威信【48527505...
透视脚本!pokemmo手机脚... 透视脚本!pokemmo手机脚本(透视)we poker免费辅助器(竟然是真的有脚本)-哔哩哔哩所有...
透视技巧!约战大同辅助(辅助)... 透视技巧!约战大同辅助(辅助)吉祥填大坑底牌图片(本来真的是有透视)-哔哩哔哩运吉祥填大坑底牌图片辅...
透视脚本!wepoker透视脚... 透视脚本!wepoker透视脚本免费(透视)wejoker辅助软件价格(真是有透视)-哔哩哔哩1、不...
透视神器!hh poker软件... 透视神器!hh poker软件(透视)hhpoker透视脚本下载(一贯有辅助器)-哔哩哔哩1、每一步...
透视攻略!黑桃a3哟西破解版(... 透视攻略!黑桃a3哟西破解版(辅助)丽水茶苑辅助有吗(一直是真的有辅助器)-哔哩哔哩1、完成丽水茶苑...
透视脚本!德扑圈透视挂(透视)... 透视脚本!德扑圈透视挂(透视)德普之星透视辅助软件(一直真的有脚本)-哔哩哔哩1、德普之星透视辅助软...
透视攻略!wpk透视辅助下载(... 透视攻略!wpk透视辅助下载(透视)wpk辅助器是真的吗(竟然真的是有透视)-哔哩哔哩小薇(辅助器软...
透视工具!wepoker私人局... 透视工具!wepoker私人局可以透视(透视)wepoker怎么挂底牌(真是一直都是有脚本)-哔哩哔...
透视脚本!wepoker辅助器... 透视脚本!wepoker辅助器安装包(透视)wepokerplus开挂(本来存在有挂)-哔哩哔哩1、...