Angular动画:未知高度变化
创始人
2024-10-24 14:00:52
0

对于这个问题,我们需要使用Angular提供的动画状态和触发器,以便在状态发生变化时执行动画。这个解决方案涉及到以下步骤:

  1. 定义变化状态(从未变化到变化后的状态)

在组件的简单模板中,添加一个类来表示变化后的状态。在下面的示例中,我们为高度变化定义了两个状态:“expanded”和“collapsed”。要在模板中使用这些状态,我们需要使用动画元数据枚举animate,设置“从原始状态到目标状态的样式”和“过渡时间”。

animations: [ trigger('expandAnimation', [ state('collapsed', style({ height: '0px', opacity: 0 })), state('expanded', style({ height: '*', opacity: 1 })), transition('collapsed <=> expanded', animate('500ms ease-in-out')) ]) ]
  1. 监测高度的变化

为了在高度发生变化时触发动画,我们需要监测容器元素高度的变化。为此,我们需要使用Angular的Renderer2服务,对DOM进行相应的操作。在组件的构造函数中,将Renderer2服务注入到组件中,在ngAfterViewInit钩子中,使用它来监测容器元素高度的变化。

constructor(private renderer: Renderer2, private elementRef: ElementRef) {}

ngAfterViewInit() {
  this.renderer.setStyle(this.elementRef.nativeElement, 'height', this.expanded ? 'auto' : '0');
  this.height = this.elementRef.nativeElement.scrollHeight + 'px';
  this.renderer.setStyle(this.element

相关内容

热门资讯

科普攻略!德普之星辅助器app... 科普攻略!德普之星辅助器app,we poker辅助器,德州论坛(有挂软件)是一款可以让一直输的玩家...
重大科普!佛手在线大菠萝智能辅... 重大科普!佛手在线大菠萝智能辅助器,wepoker作弊辅助,分享教程(有挂软件);原来确实真的有挂(...
一分钟教会你!wepoker怎... 一分钟教会你!wepoker怎么增加运气,epoker透视,切实教程(有挂透视)1、点击下载安装,微...
六分钟了解!hhpoker有辅... 六分钟了解!hhpoker有辅助吗,wepoker国外版透视,扑克教程(有挂技巧)科技教程也叫必备教...
我来教大家!wepoker辅助... 我来教大家!wepoker辅助透视,wepoker免费脚本弱密码,详细教程(有挂透明);wepoke...
记者发布!wpk辅助,德普之星... 记者发布!wpk辅助,德普之星透视辅助软件激活码,解密教程(有挂辅助);亲真的是有正版授权,小编(透...
揭秘攻略!aapoker万能辅... 《揭秘攻略!aapoker万能辅助器,hhpoker真的假的,揭秘教程(有挂教程)》 aapoker...
重大通报!sohoo poke... 自定义sohoo poker辅助器系统规律,只需要输入自己想要的开挂功能,一键便可以生成出微扑克专用...
三分钟了解!wpk辅助器,hh... 1、三分钟了解!wpk辅助器,hhpoker免费辅助器,必赢教程(有挂神器);详细教程。2、hhpo...
玩家必看攻略!wejoker私... 玩家必看攻略!wejoker私人辅助软件,智星德州可以透视吗,透明挂教程(有挂技巧)关于智星德州可以...