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

相关内容

热门资讯

连日来!老铁十三水脚本&quo... 连日来!老铁十三水脚本"曝光辅助工具"好像确实有挂(哔哩哔哩)1、金币登录送、破产送、升级送、活动送...
透视苹果版!掌中乐游戏中心破解... 透视苹果版!掌中乐游戏中心破解版"揭幕辅助脚本"好像真的是有挂(哔哩哔哩)该软件可以轻松地帮助玩家将...
刚刚!wepoker安装教程&... 刚刚!wepoker安装教程"解密辅助攻略"切实是有挂(哔哩哔哩)小薇(辅助器软件下载)致您一封信;...
2026版规律!拱趴大菠萝有辅... 2026版规律!拱趴大菠萝有辅助吗"揭幕辅助挂"切实真的有挂(哔哩哔哩)1)拱趴大菠萝有辅助吗辅助插...
透视真的!江西中指黑科技辅助软... 透视真的!江西中指黑科技辅助软件"推荐辅助插件"总是确实有挂(哔哩哔哩)江西中指黑科技辅助软件透视方...
透视辅助!皮皮跑胡子系统有鬼&... 透视辅助!皮皮跑胡子系统有鬼"详细辅助技巧"总是是真的有挂(哔哩哔哩)1、每一步都需要思考,不同水平...
有了最新消息!新道游戏辅助器免... 有了最新消息!新道游戏辅助器免费"解谜辅助教程"竟然确实有挂(哔哩哔哩)进入游戏-大厅左侧-新手福利...
出现新变化!新祥心挂机&quo... 出现新变化!新祥心挂机"关于辅助攻略"原来是真的有挂(哔哩哔哩)暗藏猫腻,小编详细说明新祥心挂机破解...
透视ai代打!广西微乐小程序微... 透视ai代打!广西微乐小程序微信辅助器免费"关于辅助app"原来存在有挂(哔哩哔哩)1、不需要AI权...
无独有偶!土豪联盟辅助&quo... 无独有偶!土豪联盟辅助"辅助辅助工具"都是真的是有挂(哔哩哔哩)1、无独有偶!土豪联盟辅助"辅助辅助...