Angular动画在完成后跳到了不希望的值
创始人
2024-10-24 13:32:03
0

要解决Angular动画在完成后跳到不希望的值的问题,可以尝试以下方法:

  1. 使用animation选项的fill属性设置为forwards,以保持动画完成后的最终状态。例如:
import { trigger, state, style, transition, animate } from '@angular/animations';

@Component({
  selector: 'app-my-component',
  template: `
    
Animate me
`, animations: [ trigger('myAnimation', [ state('active', style({ transform: 'scale(1)' })), state('inactive', style({ transform: 'scale(0)' })), transition('inactive => active', animate('500ms')), transition('active => inactive', animate('500ms')), ]), ], }) export class MyComponent { state = 'inactive'; toggleState() { this.state = this.state === 'inactive' ? 'active' : 'inactive'; } }
  1. 使用animation选项的end回调函数,在动画完成后更新元素的样式。例如:
import { trigger, state, style, transition, animate } from '@angular/animations';

@Component({
  selector: 'app-my-component',
  template: `
    
Animate me
`, animations: [ trigger('myAnimation', [ state('active', style({ transform: 'scale(1)' })), state('inactive', style({ transform: 'scale(0)' })), transition('inactive => active', animate('500ms')), transition('active => inactive', animate('500ms')), ]), ], }) export class MyComponent { state = 'inactive'; toggleState() { this.state = this.state === 'inactive' ? 'active' : 'inactive'; } onAnimationEnd(event: AnimationEvent) { if (event.toState === 'active') { event.element.style.transform = 'scale(1)'; } else if (event.toState === 'inactive') { event.element.style.transform = 'scale(0)'; } } }

在以上示例中,[@myAnimation]指令绑定到state变量,并通过点击事件toggleState()函数来切换状态。myAnimation触发器定义了两个状态activeinactive,以及状态之间的过渡动画。第一个解决方法使用了animation选项的fill属性,使得动画完成后元素保持在最终状态。第二个解决方法通过animation选项的end回调函数,在动画完成后手动更新元素的样式。

相关内容

热门资讯

十分钟绝活儿!约战竞技场辅助器... 十分钟绝活儿!约战竞技场辅助器(外挂)竟然有辅助软件(哔哩哔哩)十分钟绝活儿!约战竞技场辅助器(外挂...
第九分钟烘培!凑一桌开挂游戏辅... 第九分钟烘培!凑一桌开挂游戏辅助(外挂)其实是有辅助软件(哔哩哔哩)该软件可以轻松地帮助玩家将凑一桌...
七分钟办法!新海贝之城脚本(外... 七分钟办法!新海贝之城脚本(外挂)总是是真的有辅助技巧(哔哩哔哩)1.新海贝之城脚本 选牌创建新账号...
4分钟指引!杭麻圈辅助工具(外... 4分钟指引!杭麻圈辅助工具(外挂)其实是真的有辅助方法(哔哩哔哩)1、全新机制【杭麻圈辅助工具ai辅...
第5分钟演示!浙江茶园辅助(外... 第5分钟演示!浙江茶园辅助(外挂)都是是真的有辅助app(哔哩哔哩)1、游戏颠覆性的策略玩法,独创攻...
三分钟举措!上饶中至能操控吗(... 三分钟举措!上饶中至能操控吗(外挂)好像一直都是有辅助软件(哔哩哔哩)1、让任何用户在无需上饶中至能...
两分钟法子!新天道能不能开挂(... 两分钟法子!新天道能不能开挂(外挂)总是是有辅助教程(哔哩哔哩)1、让任何用户在无需新天道能不能开挂...
三分钟要领!玖玖互娱辅助工具(... 三分钟要领!玖玖互娱辅助工具(外挂)真是存在有辅助脚本(哔哩哔哩)三分钟要领!玖玖互娱辅助工具(外挂...
8分钟手段!wepoker私人... 8分钟手段!wepoker私人局辅助器(外挂)确实有辅助技巧(哔哩哔哩)运wepoker私人局辅助器...
2分钟步骤!科乐游戏辅助脚本视... 2分钟步骤!科乐游戏辅助脚本视频(外挂)原来是真的有辅助插件(哔哩哔哩)1、任何科乐游戏辅助脚本视频...