ホームページ > ウェブフロントエンド > jsチュートリアル > Angular で現在のページを更新するにはどうすればよいですか?手法の紹介

Angular で現在のページを更新するにはどうすればよいですか?手法の紹介

青灯夜游
リリース: 2021-04-08 11:59:15
転載
4137 人が閲覧しました

この記事では、現在のページを更新するための Angular メソッドをいくつか紹介します。一定の参考値があるので、困っている友達が参考になれば幸いです。

Angular で現在のページを更新するにはどうすればよいですか?手法の紹介

現在のページを更新する Angular のいくつかのメソッド


デフォルトでは、現在の URL に移動するリクエストがあったときを受信して​​も、Angular ルーターはそれを無視します。

<a routerLink="/heroes" routerLinkActive="active">Heroes</a>
ログイン後にコピー

同じリンクを繰り返しクリックしても、ページは更新されません。

onSameUrlNavigation 属性は、ルートのリロードをサポートするために Angular 5.1 から提供されています。

@NgModule({
  imports: [RouterModule.forRoot(routes, {onSameUrlNavigation: &#39;reload&#39;})],
  exports: [RouterModule]
})
ログイン後にコピー

onSameUrlNavigation には、「reload」と「ignore」という 2 つのオプション値があります。デフォルトは「ignore」です。ただし、onSameUrlNavigation を 'reload' に変更するだけでは RouterEvent イベントがトリガーされるだけで、ページはリロードされません。他のメソッドを使用する必要があります。続行する前に、ルーター トレースを有効にし、ブラウザ コンソールからルーティング イベント ログを確認します:

@NgModule({
  imports: [RouterModule.forRoot(routes, {onSameUrlNavigation: &#39;reload&#39;, enableTracing: true})],
  exports: [RouterModule]
})
ログイン後にコピー

onSameUrlNavigation が構成されていない場合、同じリンクを再度クリックしてもログが出力されないことがわかります。onSameUrlNavigation を ' として構成します。 reload ' を実行すると、NavigationStart、RoutesRecognized、GuardsCheckStart、GuardsCheckEnd、ActivationEnd、NavigationEnd などのイベントを含むログが出力されます。

関連チュートリアルの推奨事項: "angular チュートリアル"

以下では、現在のページを更新するいくつかの方法を紹介します:

NavigationEnd

##1. onSameUrlNavigation を「reload」として設定します

2. NavigationEnd イベントをリッスンします

Router イベントをサブスクライブし、NavigationEnd でデータをリロードし、破棄しますコンポーネント Unsubscribe:

export class HeroesComponent implements OnDestroy {
  heroes: Hero[];
  navigationSubscription;

  constructor(private heroService: HeroService, private router: Router) {
    this.navigationSubscription = this.router.events.subscribe((event: any) => {
      if (event instanceof NavigationEnd) {
        this.init();
      }
    });
  }

  init() {
    this.getHeroes();
  }

  ngOnDestroy() {
    if (this.navigationSubscription) {
      this.navigationSubscription.unsubscribe();
    }
  }
  ...
}
ログイン後にコピー

このメソッドでは、必要に応じてページが更新されるように構成できますが、コードは煩雑です。

RouteReuseStrategy

1. onSameUrlNavigation を「reload」に設定します

2. RouteReuseStrategy をカスタマイズし、Route を再利用しません

実装方法は 2 つあります:

コード内の戦略を変更します:

constructor(private heroService: HeroService, private router: Router) {
  this.router.routeReuseStrategy.shouldReuseRoute = function () {
    return false;
  };
}
ログイン後にコピー

Angular は Router をシングルトン オブジェクトとして適用するため、この方法を使用すると、1 つのコンポーネントで戦略を変更すると他のコンポーネントに影響します。ただし、ルーターはブラウザからページを更新した後に再初期化されるため、混乱を招きやすいためお勧めできません。

カスタマイズされた RouteReuseStrategy:

import {ActivatedRouteSnapshot, DetachedRouteHandle, RouteReuseStrategy} from &#39;@angular/router&#39;;

export class CustomReuseStrategy implements RouteReuseStrategy {

  shouldDetach(route: ActivatedRouteSnapshot): boolean {
    return false;
  }

  store(route: ActivatedRouteSnapshot, handle: DetachedRouteHandle | null): void {
  }

  shouldAttach(route: ActivatedRouteSnapshot): boolean {
    return false;
  }

  retrieve(route: ActivatedRouteSnapshot): DetachedRouteHandle | null {
    return null;
  }

  shouldReuseRoute(future: ActivatedRouteSnapshot, curr: ActivatedRouteSnapshot): boolean {
    return false;
  }

}
ログイン後にコピー

カスタム RouteReuseStrategy を使用する:

@NgModule({
  imports: [RouterModule.forRoot(routes, {onSameUrlNavigation: &#39;reload&#39;})],
  exports: [RouterModule],
  providers: [
    {provide: RouteReuseStrategy, useClass: CustomReuseStrategy}
  ]
})
ログイン後にコピー

このメソッドは、より複雑なルート再利用戦略を実装できます。

Resolve

Resolve を使用すると、ルートがアクティブ化される前にデータを準備できるように、事前にサーバーからデータを取得できます。

1. ResolverService の実装

コンポーネント内の初期化コードを Resolve に転送します:

import {Injectable} from &#39;@angular/core&#39;;
import {ActivatedRouteSnapshot, Resolve, RouterStateSnapshot} from &#39;@angular/router&#39;;
import {Observable} from &#39;rxjs&#39;;

import {HeroService} from &#39;../hero.service&#39;;
import {Hero} from &#39;../hero&#39;;

@Injectable({
  providedIn: &#39;root&#39;,
})
export class HeroesResolverService implements Resolve<Hero[]> {
  constructor(private heroService: HeroService) {
  }

  resolve(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): Observable<Hero[]> | Observable<never> {
    return this.heroService.getHeroes();
  }
}
ログイン後にコピー

ルーティング用のリゾルバーを構成します:

path: &#39;heroes&#39;, component: HeroesComponent, canActivate: [CanActivateAuthGuard], resolve: {heroes: HeroesResolverService}
ログイン後にコピー

2. コンポーネントを変更しますコードを、resolve


constructor(private heroService: HeroService, private route: ActivatedRoute) {
}

ngOnInit() {  this.route.data.subscribe((data: { heroes: Hero[] }) => {    this.heroes = data.heroes;
  });
}
ログイン後にコピー

3 からデータを取得するように変更します。 onSameUrlNavigation を「reload」として設定します。


4. runGuardsAndResolvers を「always」として設定します。

runGuardsAndResolversオプションの値: 'paramsChange'、'paramsOrQueryParamsChange'、'always'

{path: &#39;heroes&#39;, component: HeroesComponent, canActivate: [CanActivateAuthGuard], resolve: {heroes: HeroesResolverService}, runGuardsAndResolvers: 'always'}
ログイン後にコピー

タイム スタンプ

ルーターに時間パラメータを追加します:

<a (click)="gotoHeroes()">Heroes</a>
ログイン後にコピー
constructor(private router: Router) {
}

gotoHeroes() {  this.router.navigate([&#39;/heroes&#39;], {    queryParams: {refresh: new Date().getTime()}
  });
}
ログイン後にコピー

次に、コンポーネント内の queryParamMap をサブスクライブします:

constructor(private heroService: HeroService, private route: ActivatedRoute) {
  this.route.queryParamMap.subscribe(params => {
    if (params.get(&#39;refresh&#39;)) {
      this.init();
    }
  });
}
ログイン後にコピー
プログラミング関連の知識の詳細については、

プログラミング ビデオ を参照してください。 !

以上がAngular で現在のページを更新するにはどうすればよいですか?手法の紹介の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:51cto.com
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート