AngularRouteReuseStrategy和queryParams
创始人
2024-10-29 06:00:50
0

在Angular中,RouteReuseStrategy用于控制是否要重用一个已经存在的路由。而queryParams则定义了在路由中包含的查询参数。如何同时使用这两个功能呢?我们可以在自定义的RouteReuseStrategy实现中重写shouldReuseRoute方法,在这个方法中根据查询参数来判断是否重用已有的路由。

下面是一个示例代码:

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

export class CustomRouteReuseStrategy implements RouteReuseStrategy {

  shouldDetach(route: ActivatedRouteSnapshot): boolean {
    return false; // 返回false表示不缓存路由
  }

  store(route: ActivatedRouteSnapshot, handle: DetachedRouteHandle): void {
    // 留空即可
  }

  shouldAttach(route: ActivatedRouteSnapshot): boolean {
    return false; // 返回false表示不重用路由
  }

  retrieve(route: ActivatedRouteSnapshot): DetachedRouteHandle|null {
    return null; // 返回null表示没有可以重用的路由
  }

  shouldReuseRoute(
    future: ActivatedRouteSnapshot,
    current: ActivatedRouteSnapshot
  ): boolean {
    if (future.routeConfig !== current.routeConfig) {
      return false; // 不重用不同的路由
    }
    // 根据查询参数判断是否重用已有的路由
    const futureParams = future.queryParams;
    const currentParams = current.queryParams;
    return JSON.stringify(futureParams) === JSON.stringify(currentParams);
  }

}

以上代码中,shouldReuseRoute方法将与路由重用相关的判断条件的逻辑改写,根据两个ActivatedRouteSnapshot的queryParams来进行比较。如果两者queryParams值不同,就返回false,表示不重用已有的路由。否则的话就表示可以重用。

最后在应用中,我们需要将这个自定义的RouteReuseStrategy设置为应用的路由策略即可:

@NgModule({
  imports: [RouterModule.forRoot(routes)],
  exports: [RouterModule],
  providers: [
    { provide: RouteReuseStrategy, useClass: CustomRouteReuseStrategy } // 设置自定义的RouteReuseStrategy
  ]
})
export class AppRoutingModule { }

相关内容

热门资讯

第8分钟积累!wepoker破... 第8分钟积累!wepoker破解游戏盒子(透视)切实存在有辅助神器(哔哩哔哩)1、让任何用户在无需w...
6分钟窍要!约局吧作必弊脚本(... 6分钟窍要!约局吧作必弊脚本(透视)本来真的有辅助工具(哔哩哔哩)暗藏猫腻,小编详细说明约局吧作必弊...
9分钟绝活儿!pokerwor... 9分钟绝活儿!pokerworld辅助器(透视)竟然真的是有辅助下载(哔哩哔哩)1、首先打开poke...
十分钟指南!wepoker私人... 十分钟指南!wepoker私人局透视插件(透视)都是是有辅助下载(哔哩哔哩)1、不需要AI权限,帮助...
第七分钟法门!wpk安卓下载辅... 第七分钟法门!wpk安卓下载辅助(透视)本来存在有辅助插件(哔哩哔哩)1、wpk安卓下载辅助破解器简...
3分钟模块!hhpoker有透... 3分钟模块!hhpoker有透视功能吗(透视)一直真的是有辅助神器(哔哩哔哩)一、hhpoker有透...
六分钟项目!约局吧开挂神器是真... 六分钟项目!约局吧开挂神器是真的吗(透视)都是有辅助脚本(哔哩哔哩)1、首先打开约局吧开挂神器是真的...
八分钟方案!福建大菠萝万能辅助... 您好,福建大菠萝万能辅助器这款游戏可以开挂的,确实是有挂的,需要了解加去威信【485275054】很...
七分钟操作!wepoker透视... 七分钟操作!wepoker透视脚本免费app(透视)果然是真的有辅助插件(哔哩哔哩)1、操作简单,无...
三分钟要领!哈糖大菠萝有挂吗5... 三分钟要领!哈糖大菠萝有挂吗5个常用方法(透视)切实存在有辅助辅助(哔哩哔哩);1、操作简单,无需哈...