ホームページ >ウェブフロントエンド >CSSチュートリアル >Angular 2 でルート遷移中にロード画面を実装するにはどうすればよいですか?

Angular 2 でルート遷移中にロード画面を実装するにはどうすればよいですか?

DDD
DDDオリジナル
2024-12-06 20:38:12538ブラウズ

How to Implement a Loading Screen During Route Transitions in Angular 2?

Angular 2 でルーティング中にロード画面を表示する方法

ルート間の遷移中にロード画面を表示すると、視覚的なフィードバックが提供されるため、ユーザー エクスペリエンスが向上します。 Angular 2 では、このような遷移を管理するためのサポートが組み込まれています。

読み込み画面を実装するための鍵は、Angular の RouterEvents をサブスクライブすることです。これらのイベントは、ナビゲーション プロセスの現在の状態に関する情報を提供します。

パフォーマンス向上のための改善された回答

パフォーマンスを向上させるには、ngIf を避けることを検討してください。ローディングスピナーの条件付き表示。代わりに、NgZone と Renderer を利用して、Angular の変更検出サイクル外でスピナーの表示を切り替えます。

@Component({})
export class AppComponent {

  @ViewChild('spinnerElement') spinnerElement: ElementRef

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

  private _navigationInterceptor(event: RouterEvent): void {
    if (event instanceof NavigationStart) {
      // Show spinner outside Angular's zone to prevent change detection
      this.ngZone.runOutsideAngular(() => {
        this.renderer.setElementStyle(
          this.spinnerElement.nativeElement,
          'opacity',
          '1'
        )
      })
    }

    if (event instanceof NavigationEnd) {
      this._hideSpinner()
    }
    // Hide spinner in case of failure
    if (event instanceof NavigationCancel || event instanceof NavigationError) {
      this._hideSpinner()
    }
  }

  private _hideSpinner(): void {
    // Hide spinner outside Angular's zone to prevent change detection
    this.ngZone.runOutsideAngular(() => {
      this.renderer.setElementStyle(
        this.spinnerElement.nativeElement,
        'opacity',
        '0'
      )
    })
  }
}

HTML

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

RouterEvents をサブスクライブし、条件付きでローディング スピナーの外側の変更検出により、よりスムーズで応答性の高いナビゲーションを実現できます。体験してください。

以上がAngular 2 でルート遷移中にロード画面を実装するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。