Angular动画:组件在触发动画之前被销毁。
创始人
2024-10-24 14:00:54
0

一个可能的解决方法是将动画触发放在ngAfterViewInit生命周期钩子中执行,而不是ngOnInit中。这样可以确保组件已经初始化并完全渲染,不会在动画触发之前被销毁。 示例代码:

import { Component, AfterViewInit, ViewChild, ElementRef } from '@angular/core'; import { trigger, state, style, animate, transition } from '@angular/animations';

@Component({ selector: 'app-my-component', templateUrl: './my-component.component.html', styleUrls: ['./my-component.component.css'], animations: [ trigger('myAnimation', [ state('start', style({ opacity: 1 })), state('end', style({ opacity: 0 })), transition('start => end', [ animate('1s') ]) ]) ] }) export class MyComponent implements AfterViewInit { @ViewChild('myElement') myElement: ElementRef;

ngOnInit() { // This won't work because the element hasn't been rendered yet this.myElement.nativeElement.classList.toggle('myClass'); this.triggerAnimation(); }

ngAfterViewInit() { // This will work because the element has been rendered this.myElement.nativeElement.classList.toggle('myClass'); this.triggerAnimation(); }

triggerAnimation() { this.state = 'end'; } }

在这个示例中,我们在ngAfterViewInit的生命周期钩子中调用triggerAnimation()方法来触发动画。在ngOnInit中调用无法正确工作,因为组件尚未完全初始化并渲染。

相关内容

热门资讯

为了进一步!微信微乐小程序辅助... 为了进一步!微信微乐小程序辅助软件,赣牌圈的好牌几率(透视)技巧-一贯真的是有挂1、让任何用户在无需...
此事引发广泛关注!新世界辅助器... 此事引发广泛关注!新世界辅助器免费下载,方片十三张脚本(透视)脚本-都是是有挂1、超多福利:超高返利...
这一现象值得深思!上饶中至脚本... 这一现象值得深思!上饶中至脚本,玄龙辅助工具(透视)脚本-其实真的是有挂1、玄龙辅助工具破解器简单,...
为切实保障!中至鹰潭亲友圈辅助... 为切实保障!中至鹰潭亲友圈辅助,掌中乐游戏辅助工具(透视)技巧-果然真的是有挂;一、掌中乐游戏辅助工...
突发!欢聚水鱼神器,麻辣竞技辅... 突发!欢聚水鱼神器,麻辣竞技辅助(透视)神器-切实有挂1、很好的工具软件,可以解锁游戏的欢聚水鱼神器...
据通报!功夫川麻老是输什么情况... 据通报!功夫川麻老是输什么情况,博雅红河西元红河修改器(透视)脚本-好像存在有挂1、任何博雅红河西元...
随着!新九哥透视,天天贵阳辅助... 随着!新九哥透视,天天贵阳辅助工具(透视)攻略-其实真的是有挂小薇(辅助器软件下载)致您一封信;亲爱...
目前!边锋老友填大坑辅助,新畅... 目前!边锋老友填大坑辅助,新畅游互娱辅助(透视)插件-好像是有挂暗藏猫腻,小编详细说明边锋老友填大坑...
今日!随意玩辅助软件,战神辅助... 今日!随意玩辅助软件,战神辅助众包(透视)软件-一直有挂1、任何随意玩辅助软件透视是真的假的的玩家都...
今天下午!好友赣南脚本插件,邯... 今天下午!好友赣南脚本插件,邯郸胡乐挂(透视)技巧-一贯存在有挂小薇(辅助器软件下载)致您一封信;亲...