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

相关内容

热门资讯

透视美元局!哈糖大菠萝怎么挂,... 透视美元局!哈糖大菠萝怎么挂,哈糖大菠萝攻略,2025教程(有挂辅助);哈糖大菠萝怎么挂辅助器中分为...
透视中牌率!wejoker辅助... 透视中牌率!wejoker辅助器要钱玩吗,起初是有挂(透视)新2025版(有挂教程)1、wejoke...
透视安卓版!德州透视是真的假的... 透视安卓版!德州透视是真的假的,pokemmo手机版修改器,2025新版(有挂脚本);1、许多玩家不...
透视好友房!wepoker辅助... 透视好友房!wepoker辅助真的假的,起初是有挂(透视)透牌教程(有挂详情);wepoker辅助真...
透视好友房!uupoker有透... 透视好友房!uupoker有透视吗,pokernow辅助控制,玩家教你(有挂黑科技);1、不需要AI...
透视辅助!aapoker透视脚... 透视辅助!aapoker透视脚本下载,总是有挂(透视)技巧教程(有挂攻略);在进入aapoker透视...
透视中牌率!pokemmo脚本... 透视中牌率!pokemmo脚本辅助器下载,佛手在线大菠萝智能辅助器,黑科技教程(有挂介绍);1)佛手...
透视软件!hhpoker怎么破... 透视软件!hhpoker怎么破解,先前真的有挂(透视)总结教程(有挂细节)1、上手简单,内置详细流程...
透视肯定!聚星ai辅助工具激活... 透视肯定!聚星ai辅助工具激活码,哈糖大菠萝攻略,必赢方法(有挂揭秘)一、聚星ai辅助工具激活码AI...
透视美元局!xpoker透视辅... 透视美元局!xpoker透视辅助,原来有挂(透视)科技教程(有挂细节)1、下载好xpoker透视辅助...