Maison >interface Web >tutoriel CSS >Comment puis-je afficher un écran de chargement lors des changements d'itinéraire dans Angular 2 ?

Comment puis-je afficher un écran de chargement lors des changements d'itinéraire dans Angular 2 ?

Mary-Kate Olsen
Mary-Kate Olsenoriginal
2024-12-09 21:44:15750parcourir

How Can I Display a Loading Screen During Route Changes in Angular 2?

Affichage d'un écran de chargement lors des changements d'itinéraire dans Angular 2

Dans Angular 2, la navigation entre les itinéraires peut déclencher l'affichage d'un écran de chargement, fournissant une indication visuelle de la transition de l'application.

Utilisation de la navigation Événements

Le routeur angulaire propose des événements de navigation qui suivent la progression des changements d'itinéraire. En vous abonnant à ces événements, vous pouvez manipuler l'interface utilisateur en conséquence, notamment en affichant un écran de chargement. Voici comment :

app.component.ts (composant racine)

import { Router, Event as RouterEvent, NavigationStart, NavigationEnd, NavigationCancel, NavigationError } from '@angular/router';

@Component({/* ... */})
export class AppComponent {

  // Initialize loading indicator
  loading = true;

  constructor(private router: Router) {
    router.events.subscribe((e: RouterEvent) => this.navigationInterceptor(e));
  }

  navigationInterceptor(event: RouterEvent): void {
    if (event instanceof NavigationStart) {
      this.loading = true;
    }
    if (event instanceof NavigationEnd) {
      this.loading = false;
    }
    if (event instanceof NavigationCancel || event instanceof NavigationError) {
      this.loading = false;
    }
  }
}

app.component.html (vue racine)

<div class="loading-overlay" *ngIf="loading">
  <!-- Show loading animation, e.g., spinner -->
</div>

Performances Amélioration

Pour des performances améliorées, exploitez NgZone et Renderer d'Angular pour contrôler la visibilité de l'écran de chargement. Cela contourne la détection des modifications, ce qui entraîne des transitions d'animation plus fluides :

app.component.ts (composant racine mis à jour)

import { NgZone, Renderer, ElementRef, ViewChild } from '@angular/core';

@Component({/* ... */})
export class AppComponent {

  @ViewChild('spinnerElement')
  spinnerElement: ElementRef;

  constructor(private ngZone: NgZone,
              private renderer: Renderer,
              private router: Router) {
    router.events.subscribe(this._navigationInterceptor);
  }

  private _navigationInterceptor(event: RouterEvent): void {
    if (event instanceof NavigationStart) {
      this.ngZone.runOutsideAngular(() => {
        this.renderer.setElementStyle(
          this.spinnerElement.nativeElement,
          'opacity',
          '1'
        );
      });
    }
    if (event instanceof NavigationEnd) {
      this._hideSpinner();
    }
    if (event instanceof NavigationCancel || event instanceof NavigationError) {
      this._hideSpinner();
    }
  }

  private _hideSpinner(): void {
    this.ngZone.runOutsideAngular(() => {
      this.renderer.setElementStyle(
        this.spinnerElement.nativeElement,
        'opacity',
        '0'
      );
    });
  }
}

app.component.html (Vue racine mise à jour)

<div class="loading-overlay" #spinnerElement>

En mettant en œuvre ces techniques, vous pouvez gérer efficacement la visibilité d'un écran de chargement lors de la navigation sur un itinéraire dans Angular 2, améliorant l'expérience utilisateur avec un retour visuel clair.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn