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

相关内容

热门资讯

3分钟解密!破解大菠萝的辅助器... 3分钟解密!破解大菠萝的辅助器,闲来辅助平台(竟然是有挂)-哔哩哔哩1、破解大菠萝的辅助器系统规律教...
第八分钟外挂!wepoker专... 第八分钟外挂!wepoker专用辅助,决战卡五星有挂吗,技巧教程(有挂实锤)-哔哩哔哩决战卡五星有挂...
第四分钟普及!熊猫互娱辅助,乐... 第四分钟普及!熊猫互娱辅助,乐乐围棋入门辅助器(切实存在有挂)-哔哩哔哩乐乐围棋入门辅助器辅助器中分...
5分钟揭幕!拱趴大菠萝技巧,汇... 5分钟揭幕!拱趴大菠萝技巧,汇友游戏辅助软件(原来是真的挂)-哔哩哔哩1、操作简单,无需注册,只需要...
第一分钟外挂!人皇辅助软件下载... 第一分钟外挂!人皇辅助软件下载,悟空大厅辅助助手下载安装,可靠教程(有挂讲解)-哔哩哔哩1、悟空大厅...
第7分钟普及!多乐找刺激技巧辅... 第7分钟普及!多乐找刺激技巧辅助,传送屋有没有挂(切实是真的挂)-哔哩哔哩亲,关键说明,多乐找刺激技...
第3分钟外挂!中至吉安祈福有用... 第3分钟外挂!中至吉安祈福有用吗,丽水都莱脚本辅助视频,实用技巧(果真有挂)-哔哩哔哩;1、操作简单...
第9分钟解密!福建开心辅助,微... 第9分钟解密!福建开心辅助,微乐陕西三代自建房挂(好像有挂)-哔哩哔哩1、下载好微乐陕西三代自建房挂...
第三分钟外挂!爱来大菠萝的辅助... 第三分钟外挂!爱来大菠萝的辅助七,玖天乐游辅助,透牌教程(有挂教程)-哔哩哔哩1、爱来大菠萝的辅助七...
第1分钟专业!中至鹰潭辅助器,... 第1分钟专业!中至鹰潭辅助器,新天道破解版(都是真的是有挂)-哔哩哔哩1、中至鹰潭辅助器系统规律教程...