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、起透看视 辅助软件价格2...
微乐小程序真的有挂!微信小程序... 微乐小程序真的有挂!微信小程序微乐辅助器app(开挂)器-果然推荐有挂1、全新机制【ai辅助工具激活...
微乐小程序存在有挂!微乐家乡a... 微乐小程序存在有挂!微乐家乡app辅助器(开挂)挂-切实总结真的是有挂透视方法中分为三种模型:靠谱、...
微乐小程序黑科技免费!微信小程... 微乐小程序黑科技免费!微信小程序微乐破解填大坑(开挂)软件-都是开挂真的是有挂一、可以开透视的定义与...
微乐小程序透视挂!小程序微乐辅... 微乐小程序透视挂!小程序微乐辅助软件(开挂)插件-确实解谜真的有挂1、打开软件启动之后找到中间准星的...
微乐小程序黑科技!微乐游戏辅助... 微乐小程序黑科技!微乐游戏辅助脚本安卓(开挂)软件-竟然透视真的有挂1、在插件功能辅助器技巧中,中转...
微乐小程序存在有挂!微乐家乡麻... 微乐小程序存在有挂!微乐家乡麻将辅助(开挂)脚本-都是推荐真的是有挂1、进入到是否有挂之后,能看到左...