Angulaire 4 - Animations
Les animations ajoutent beaucoup d'interaction entre les éléments html. L'animation était également disponible avec Angular2. La différence avec Angular 4 est que l'animation ne fait plus partie de la@angular/core bibliothèque, mais est un package distinct qui doit être importé dans app.module.ts.
Pour commencer, nous devons importer la bibliothèque comme suit -
import { BrowserAnimationsModule } from '@angular/platform-browser/animations';
le BrowserAnimationsModule doit être ajouté au tableau d'importation dans app.module.ts comme indiqué ci-dessous -
app.module.ts
import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';
import { BrowserAnimationsModule } from '@angular/platform-browser/animations';
import { AppComponent } from './app.component';
@NgModule({
declarations: [
AppComponent
],
imports: [
BrowserModule,
BrowserAnimationsModule
],
providers: [],
bootstrap: [AppComponent]
})
export class AppModule { }
Dans app.component.html, nous avons ajouté les éléments html, qui doivent être animés.
<div>
<button (click)="animate()">Click Me</button>
<div [@myanimation] = "state" class="rotate">
<img src="assets/images/img.png" width="100" height="100">
</div>
</div>
Pour le div principal, nous avons ajouté un bouton et un div avec une image. Il existe un événement de clic pour lequel la fonction d'animation est appelée. Et pour le div, le@myanimation La directive est ajoutée et reçoit la valeur comme état.
Voyons maintenant le app.component.ts où l'animation est définie.
import { Component } from '@angular/core';
import { trigger, state, style, transition, animate } from '@angular/animations';
@Component({
selector: 'app-root',
templateUrl: './app.component.html',
styleUrls: ['./app.component.css'],
styles:[`
div{
margin: 0 auto;
text-align: center;
width:200px;
}
.rotate{
width:100px;
height:100px;
border:solid 1px red;
}
`],
animations: [
trigger('myanimation',[
state('smaller',style({
transform : 'translateY(100px)'
})),
state('larger',style({
transform : 'translateY(0px)'
})),
transition('smaller <=> larger',animate('300ms ease-in'))
])
]
})
export class AppComponent {
state: string = "smaller";
animate() {
this.state= this.state == 'larger' ? 'smaller' : 'larger';
}
}
Nous devons importer la fonction d'animation qui doit être utilisée dans le fichier .ts comme indiqué ci-dessus.
import { trigger, state, style, transition, animate } from '@angular/animations';
Ici, nous avons importé le déclencheur, l'état, le style, la transition et l'animation à partir de @ angular / animations.
Maintenant, nous allons ajouter la propriété animations au décorateur @Component () -
animations: [
trigger('myanimation',[
state('smaller',style({
transform : 'translateY(100px)'
})),
state('larger',style({
transform : 'translateY(0px)'
})),
transition('smaller <=> larger',animate('300ms ease-in'))
])
]
Le déclencheur définit le début de l'animation. Le premier paramètre est le nom de l'animation à donner à la balise html à laquelle l'animation doit être appliquée. Le deuxième paramètre sont les fonctions que nous avons importées - état, transition, etc.
le stateLa fonction implique les étapes d'animation entre lesquelles l'élément fera la transition. À l'heure actuelle, nous avons défini deux états, plus petit et plus grand. Pour les petits états, nous avons donné le styletransform:translateY(100px) et transform:translateY(100px).
La fonction de transition ajoute une animation à l'élément html. Le premier argument prend les états, c'est-à-dire le début et la fin; le deuxième argument accepte la fonction animée. La fonction d'animation vous permet de définir la durée, le délai et l'accélération d'une transition.
Voyons maintenant le fichier .html pour voir comment fonctionne la fonction de transition
<div>
<button (click)="animate()">Click Me</button>
<div [@myanimation] = "state" class="rotate">
<img src="assets/images/img.png" width="100" height="100">
</div>
</div>
Une propriété de style a été ajoutée dans le @componentdirective, qui aligne le div. Prenons l'exemple suivant pour comprendre la même chose -
styles:[`
div{
margin: 0 auto;
text-align: center;
width:200px;
}
.rotate{
width:100px;
height:100px;
border:solid 1px red;
}
`],
Ici, un caractère spécial [``] est utilisé pour ajouter des styles à l'élément html, le cas échéant. Pour le div, nous avons donné le nom de l'animation défini dans le fichier app.component.ts.
En cliquant sur un bouton, il appelle la fonction animer, qui est définie dans le fichier app.component.ts comme suit -
export class AppComponent {
state: string = "smaller";
animate() {
this.state= this.state == ‘larger’? 'smaller' : 'larger';
}
}
La variable d'état est définie et la valeur par défaut est plus petite. La fonction d'animation change l'état au clic. Si l'état est plus grand, il sera converti en plus petit; et s'il est plus petit, il sera converti en plus grand.
C'est ainsi que la sortie dans le navigateur (http://localhost:4200/) ressemblera à -
En cliquant sur le Click Me bouton, la position de l'image est modifiée comme indiqué dans la capture d'écran suivante -
La fonction de transformation est appliquée dans le ydirection, qui passe de 0 à 100 px lorsque l'utilisateur clique sur le bouton Cliquez sur moi. L'image est stockée dans leassets/images dossier.