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

相关内容

热门资讯

透视脚本!aapoker辅助怎... 透视脚本!aapoker辅助怎么用,hhpoker真的有透视吗,经验教程(有挂教学)-哔哩哔哩进入游...
透视辅助!hhpoker辅助软... 透视辅助!hhpoker辅助软件是真的么,德州hhpoker脚本,手段教程(真是有挂)-哔哩哔哩1、...
透视有挂!wepoker怎么破... 透视有挂!wepoker怎么破解游戏,uupoker透视,模块教程(有挂方法)-哔哩哔哩1、操作简单...
透视有挂!we poker辅助... 透视有挂!we poker辅助器,约局吧开挂神器是真的吗,练习教程(讲解有挂)-哔哩哔哩1、上手简单...
透视实锤!哈糖大菠萝免费辅助器... 透视实锤!哈糖大菠萝免费辅助器,wepoker模拟器哪个好用,方案教程(讲解有挂)-哔哩哔哩哈糖大菠...
透视安卓版!wepoker可以... 透视安卓版!wepoker可以免费玩吗,poker world辅助器,办法教程(有挂方法)-哔哩哔哩...
透视软件!we poker插件... 透视软件!we poker插件,wepoker俱乐部辅助器,攻略教程(有挂实锤)-哔哩哔哩1、玩家可...
透视代打!约局吧开挂,wpk是... 透视代打!约局吧开挂,wpk是真的还是假的,积累教程(有挂头条)-哔哩哔哩所有人都在同一条线上,像星...
透视辅助!微扑克微乐辅助,we... 透视辅助!微扑克微乐辅助,wepoker透视有没有,机巧教程(存在有挂)-哔哩哔哩1、wepoker...
透视好友房!wepoker买钻... 透视好友房!wepoker买钻石有用吗,德州透视插件,操作教程(有挂技巧)-哔哩哔哩1、游戏颠覆性的...