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中调用无法正确工作,因为组件尚未完全初始化并渲染。

相关内容

热门资讯

透视代打!德普之星怎么开辅助,... 透视代打!德普之星怎么开辅助,微乐自建房脚本下载,透视脚本(今日头条)-哔哩哔哩该软件可以轻松地帮助...
脚本解谜!aapoker破解侠... 脚本解谜!aapoker破解侠是真的吗,aapoker怎么选牌(透视)都是是有软件(哔哩哔哩)1、全...
脚本分享!wepoker究竟有... 脚本分享!wepoker究竟有没有透视,wepoker透视脚本免费使用视频(透视)原来真的是有挂(哔...
一直以来!aa poker辅助... 一直以来!aa poker辅助,微乐小程序辅助教程,推荐脚本(新版有挂)-哔哩哔哩1、用户打开应用后...
脚本揭露!aapoker透视方... 脚本揭露!aapoker透视方法,aapoker透视插件(透视)总是真的是有插件(哔哩哔哩)运辅助工...
此事引发广泛关注!wpk德州局... 此事引发广泛关注!wpk德州局怎么透视,微乐山西脚本插件,必备脚本(有挂透视)-哔哩哔哩;在进入wp...
透视专业!wpk透视辅助,wp... 透视专业!wpk透视辅助,wpk透视插件(透视)总是真的有脚本(哔哩哔哩)1、进入游戏-大厅左侧-新...
受玩家影响!pokemmo手机... 受玩家影响!pokemmo手机脚本辅助器,微乐智能辅助真的假的,了解脚本(有挂教程)-哔哩哔哩1、很...
脚本科普!aapoker安装包... 脚本科普!aapoker安装包怎么使用,aapoker辅助插件工具(透视)一贯真的有方法(哔哩哔哩)...
不少玩家反映!哈糖大菠萝怎么开... 不少玩家反映!哈糖大菠萝怎么开挂,微信小程序微乐辅助器免费版v2.0,必备透视(有挂分享)-哔哩哔哩...