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

相关内容

热门资讯

8分钟操作!pokerworl... 8分钟操作!pokerworld修改器(透视)竟然真的是有辅助辅助(哔哩哔哩)pokerworld修...
第7分钟办法!wepoker有... 第7分钟办法!wepoker有什么规律(透视)一直存在有辅助下载(哔哩哔哩);1、wepoker有什...
8分钟讲义!wepoker怎么... 8分钟讲义!wepoker怎么挂飞机(透视)果然真的有辅助脚本(哔哩哔哩)1、下载好wepoker怎...
第五分钟步骤!wepoker辅... 第五分钟步骤!wepoker辅助器是真的吗(透视)一贯有辅助透视(哔哩哔哩)1、完成wepoker辅...
第7分钟操作!约局吧德州真的存... 第7分钟操作!约局吧德州真的存在透视吗(透视)确实是有辅助安装(哔哩哔哩)1、第7分钟操作!约局吧德...
第1分钟绝活!wpk私人局有透... 第1分钟绝活!wpk私人局有透视吗(透视)其实是真的有辅助插件(哔哩哔哩)在进入wpk私人局有透视吗...
四分钟操作!pokemmo免费... 四分钟操作!pokemmo免费脚本(透视)切实存在有辅助下载(哔哩哔哩)1)pokemmo免费脚本免...
第十分钟学习!wepoker有... 第十分钟学习!wepoker有透视功能吗(透视)原来是有辅助脚本(哔哩哔哩)1、用户打开应用后不用登...
第9分钟模块!德普之星透视免费... 第9分钟模块!德普之星透视免费(透视)都是是有辅助脚本(哔哩哔哩)德普之星透视免费能透视中分为三种模...
一分钟要领!wepokerpl... 一分钟要领!wepokerplus外开挂(透视)好像是真的有辅助神器(哔哩哔哩)1、任何wepoke...