1

如何使用 angular2 动画显示 X 秒的标签?理想情况下,我想saved!在我的输入框旁边显示一个标签,该标签会淡入并停留 2 秒,然后淡出。我可以很容易地让动画淡出它,但我怎样才能让它淡出呢?

这是我的动画:

animations: [
    trigger('hasSaved', [
        state('inactive', style({
            opacity: 0
        })),
        state('active', style({
            opacity: 1
        })),
        transition('inactive => active', [
            animate(500)
        ])
    ])
]
4

1 回答 1

2

演示:https ://plnkr.co/edit/yfSdg1qoYz3oHzLWfG1U?p=preview

您可以使用 *ngIf 和setTimeout一起来实现它。

keyframes用来添加动画。

animations: [
  trigger('hasSaved', [
    transition('void => *', [
      animate(1000, keyframes([
        style({opacity: 0, transform: 'translateX(-10%)',     offset: 0}),
        style({opacity: 1, transform: 'translateX(-40px)', offset: 0.3}),
        style({opacity: 1, transform: 'translateX(0)',  offset: 1.0})
      ]))
    ]),
    transition('* => void', [
      animate(1000, keyframes([
        style({opacity: 1, transform: 'translateX(0)',     offset: 0}),
        style({opacity: 1, transform: 'translateX(30px)', offset: 0.3}),
        style({opacity: 1, transform: 'translateX(20%)',  offset: 1.0})
      ]))
    ])
  ])
]

export class App {
  showSave:boolean=false;
  title = 'app works!';

  save(){
     this.showSave=!this.showSave;  
      setTimeout(()=>{
         this.showSave=!this.showSave;  
      },2000)

  }
}
于 2016-10-28T19:00:05.930 回答