Angular 路由导航重新加载延迟加载的父组件
创始人
2024-10-19 11:01:20
0

在Angular中,可以使用RouteReuseStrategy来重新加载延迟加载的父组件。下面是一个包含代码示例的解决方法:

  1. 创建一个自定义的RouteReuseStrategy类,该类将用于重新加载延迟加载的父组件。
import { ActivatedRouteSnapshot, DetachedRouteHandle, RouteReuseStrategy } from '@angular/router';

export class CustomRouteReuseStrategy implements RouteReuseStrategy {
  shouldDetach(route: ActivatedRouteSnapshot): boolean {
    return false;
  }

  store(route: ActivatedRouteSnapshot, detachedTree: DetachedRouteHandle): void {}

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

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

  shouldReuseRoute(future: ActivatedRouteSnapshot, curr: ActivatedRouteSnapshot): boolean {
    return false;
  }
}
  1. 在应用的app.module.ts中,将自定义的RouteReuseStrategy提供给RouterModule
import { NgModule } from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { RouterModule, RouteReuseStrategy } from '@angular/router';

import { AppComponent } from './app.component';
import { CustomRouteReuseStrategy } from './custom-route-reuse-strategy';

@NgModule({
  declarations: [AppComponent],
  imports: [BrowserModule, RouterModule.forRoot([...])],
  providers: [
    { provide: RouteReuseStrategy, useClass: CustomRouteReuseStrategy }
  ],
  bootstrap: [AppComponent]
})
export class AppModule {}
  1. 在需要重新加载延迟加载的父组件的地方,使用RouterNavigationEnd事件来手动重新加载父组件。
import { Component } from '@angular/core';
import { ActivatedRoute, NavigationEnd, Router } from '@angular/router';

@Component({
  selector: 'app-parent',
  template: `
    

Parent Component

... ` }) export class ParentComponent { constructor(private router: Router, private activatedRoute: ActivatedRoute) { this.router.events.subscribe(event => { if (event instanceof NavigationEnd && event.id === 1) { // 判断是否为初次加载 const currentRoute = this.activatedRoute.root.firstChild.snapshot.routeConfig; if (currentRoute && currentRoute.loadChildren) { // 重新加载父组件 this.router.navigated = false; this.router.navigate([currentRoute.path]); } } }); } }

通过使用自定义的RouteReuseStrategy和手动重新加载父组件,可以实现延迟加载的父组件的重新加载。

相关内容

热门资讯

五分钟操作!拱趴大菠萝挂怎么安... 五分钟操作!拱趴大菠萝挂怎么安装(透视)好像是真的有辅助辅助(哔哩哔哩)1、进入到拱趴大菠萝挂怎么安...
第2分钟课程!pokermas... 第2分钟课程!pokermaster脚本(透视)其实真的有辅助辅助(哔哩哔哩)1、让任何用户在无需p...
第8分钟步骤!wepoker作... 第8分钟步骤!wepoker作必弊方法(透视)好像存在有辅助教程(哔哩哔哩)小薇(辅助器软件下载)致...
第四分钟大纲!hhpoker免... 第四分钟大纲!hhpoker免费辅助器(透视)总是真的是有辅助教程(哔哩哔哩)进入游戏-大厅左侧-新...
第一分钟妙计!wepoker数... 第一分钟妙计!wepoker数据分析(透视)原来有辅助插件(哔哩哔哩)1、第一分钟妙计!wepoke...
1分钟方案!wepoker可以... 1分钟方案!wepoker可以开透视吗(透视)竟然存在有辅助下载(哔哩哔哩)1、1分钟方案!wepo...
两分钟步骤!hhpoker有辅... 两分钟步骤!hhpoker有辅助吗(透视)一直存在有辅助安装(哔哩哔哩)1、用户打开应用后不用登录就...
第九分钟窍门!wepoker辅... 第九分钟窍门!wepoker辅助软件价格(透视)都是存在有辅助辅助(哔哩哔哩)1、玩家可以在wepo...
第七分钟手册!德州透视hhpo... 第七分钟手册!德州透视hhpoker(透视)本来是真的有辅助插件(哔哩哔哩)1、用户打开应用后不用登...
六分钟攻略!wepoker代打... 六分钟攻略!wepoker代打辅助(透视)本来是有辅助辅助(哔哩哔哩)1、wepoker代打辅助辅助...