>웹 프론트엔드 >JS 튜토리얼 >Angular에서 특정 경로를 분리하기 위해 사용자 정의 RouteReuseStrategy를 구현하는 방법은 무엇입니까?

Angular에서 특정 경로를 분리하기 위해 사용자 정의 RouteReuseStrategy를 구현하는 방법은 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2024-10-25 08:37:02863검색

How to Implement a Custom RouteReuseStrategy to Detach Specific Routes in Angular?

Angular 2에서 특정 경로에 대해 RouteReuseStrategy의 shouldDetach 구현

Background

RouteReuseStrategy를 사용하면 탐색할 때 구성 요소를 파괴하는 대신 구성 요소를 유지하도록 Angular에 지시할 수 있습니다. , 성능을 최적화하고 구성 요소의 상태를 보존합니다.

문제 설명

"/documents"와 같은 경로에 대해서는 상태를 저장하려고 하지만 "/documents/:id"와 같은 특정 경로에 대해서는 상태를 저장하려고 하지 않습니다.

솔루션

내장된 RouteReuseStrategy를 확장하고 적절한 메소드를 재정의하여 사용자 정의 RouteReuseStrategy를 구현하십시오.

Angular 라우터에서 가져오기

<code class="typescript">import { RouteReuseStrategy } from '@angular/router';</code>

RouteReuseStrategy를 구현하는 클래스 생성

<code class="typescript">export class CustomRouteReuseStrategy implements RouteReuseStrategy {</code>

선택적 경로 저장에 대한 'shouldDetach' 재정의

<code class="typescript">shouldDetach(route: ActivatedRouteSnapshot): boolean {
  return route.routeConfig?.path === '/documents/id';
}</code>

NgModule에서 맞춤형 전략 제공

<code class="typescript">providers: [
  { provide: RouteReuseStrategy, useClass: CustomRouteReuseStrategy },
]</code>

설명

  • shouldDetach: 경로 저장을 제어합니다. 저장하려는 경로에 대해 true를 반환합니다. 이 시나리오에서는 "/documents" 경로만 저장합니다.
  • shouldAttach: 저장된 경로를 재사용할 시기를 결정합니다. 이 메서드가 true를 반환하면 Angular는 구성 요소를 다시 만드는 대신 구성 요소를 재사용합니다. 이 예에서는 이 메서드를 재정의하지 않습니다.

추가 참고 사항:

  • 이 구현은 사용자의 전체 경로에 걸쳐 각 정규 경로의 인스턴스 하나를 저장합니다. 세션.
  • shouldDetach를 수정하여 요구 사항에 따라 저장할 경로를 제어하여 추가로 사용자 정의할 수 있습니다.

위 내용은 Angular에서 특정 경로를 분리하기 위해 사용자 정의 RouteReuseStrategy를 구현하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.