Angular的RouteReuseStrategy与LazyLoadedModule搭配使用时,在路由到另一个模块后,MainLayout没有消失且[routerLinks]不起作用
创始人
2024-10-24 09:31:04
0

要解决这个问题,需要在应用程序中实现自定义的RouteReuseStrategy。使用自定义的RouteReuseStrategy可让我们决定在路由时是否应重复使用组件实例。我们可以使用RouteReuseStrategy接口中的shouldDetach,store,shouldAttach和retrieve方法将路由元数据存储在内存中,并在下次访问该路由时重新使用它们。

以下是解决此问题的代码示例:

import {RouteReuseStrategy, DetachedRouteHandle} from '@angular/router';

export class CustomRouteReuseStrategy extends RouteReuseStrategy {

  private handlers: {[key: string]: DetachedRouteHandle} = {};

  shouldDetach(route: import("@angular/router").ActivatedRouteSnapshot): boolean {
    return !!route.data.reuse;
  }

  store(route: import("@angular/router").ActivatedRouteSnapshot, handle: DetachedRouteHandle): void {
    this.handlers[route.url.join('/')] = handle;
  }

  shouldAttach(route: import("@angular/router").ActivatedRouteSnapshot): boolean {
    return !!this.handlers[route.url.join('/')];
  }

  retrieve(route: import("@angular/router").ActivatedRouteSnapshot): DetachedRouteHandle {
    if (!route.routeConfig || route.routeConfig.loadChildren || !this.handlers[route.url.join('/')]) {
      return null;
    }
    return this.handlers[route.url.join('/')];
  }

  shouldReuseRoute(future: import("@angular/router").ActivatedRouteSnapshot, curr: import("@angular/router").ActivatedRouteSnapshot): boolean {
    return future.routeConfig === curr.routeConfig;
  }
}

在应用程序的模块中,只需将CustomRouteReuseStrategy添加到providers数组中即可:

import { NgModule } from '@angular/core';
import { CommonModule } from '@angular/common';
import { RouterModule, RouteReuseStrategy } from '@angular/router';
import { CustomRouteReuseStrategy } from './custom-route-reuse-strategy';

@NgModule({
  imports: [
    CommonModule,
    RouterModule.forRoot(routes)
  ],
  providers: [
    {

相关内容

热门资讯

外挂模板!约局吧app有挂吗,... 外挂模板!约局吧app有挂吗,智星德州有脚本吗-原来一直总是有辅助软件(哔哩哔哩)智星德州有脚本吗辅...
外挂演示!佛手大菠萝辅助,德普... 外挂演示!佛手大菠萝辅助,德普之星透视辅助软件-总是一直总是有辅助软件(哔哩哔哩)1、打开软件启动之...
外挂积累!约局吧作必弊脚本,智... 外挂积累!约局吧作必弊脚本,智星德州插件-果然是真的有辅助攻略(哔哩哔哩)在进入约局吧作必弊脚本软件...
外挂指引!大菠萝789辅助器下... 外挂指引!大菠萝789辅助器下载,德州透视是真的吗-本来是真的有辅助神器(哔哩哔哩)1、很好的工具软...
外挂策略!德普之星透视辅助软件... 外挂策略!德普之星透视辅助软件激活码,德普之星透视辅助软件-真是是真的有辅助方法(哔哩哔哩)1、上手...
外挂机巧!哈糖大菠萝有没有挂,... 外挂机巧!哈糖大菠萝有没有挂,智星德州可以透视吗-确实存在有辅助app(哔哩哔哩)1、哈糖大菠萝有没...
外挂窍门!德普之星app安卓版... 外挂窍门!德普之星app安卓版破解版,竞技联盟透视插件-一贯一直总是有辅助教程(哔哩哔哩)1、竞技联...
外挂窍门!fishpoker透... 外挂窍门!fishpoker透视底牌,德州辅助工具到底怎么样-本来存在有辅助技巧(哔哩哔哩)一、德州...
外挂法门!聚星ai辅助工具收费... 外挂法门!聚星ai辅助工具收费多少,德普之星透视辅助插件-本来真的是有辅助软件(哔哩哔哩)外挂法门!...
外挂教材!德普之星私人局透视,... 外挂教材!德普之星私人局透视,大菠萝辅助器-都是真的有辅助工具(哔哩哔哩)运大菠萝辅助器辅助工具,进...