路由更改时销毁 Angular 服务

Kae*_*ael 3 angular-providers angular angular-router

我有一个名为MyPageModule导入多个模块的复杂模块,它为 Service 提供以下注释@Injectable( { providedIn: 'root' } )

这个模块是通过延迟加载导入的,如下所示:

// AppRoutingModule
...
 {
    path: 'my-page',
    loadChildren: './lazy-loader-modules/lazy-loader-mypage/lazy-loader-mypage.module#LazyLoaderMyPageModule'
 }

...
Run Code Online (Sandbox Code Playgroud)
// LazyLoaderMyPageModule
@NgModule({
  declarations: [],
  imports: [
    CommonModule,
    MyPageModule
  ]
})
export class LazyLoaderMyPageModule { }
Run Code Online (Sandbox Code Playgroud)

我想要的行为(实际情况并非如此): 当 url 与 /my-page/* 不同时,我希望 MyPageModule 导入的所有服务都被销毁。

我怎样才能做到这一点 ?

Tia*_*gas 5

使用路由器出口在延迟加载的模块上创建根组件,并在组件元数据上添加提供程序

@Component({
  selector: 'app-my-page-root',
  template: '<router-outlet></router-outlet>',
  styleUrls: ['./my-page-root.component.scss'],
  providers:[MyPageService, MyPageOtherService]
}) 
class MyPageRootComponent {}
Run Code Online (Sandbox Code Playgroud)

将延迟加载的模块路由更改为:

const routes= [
 { 
    path: '',
    component: MyPageRootComponent
    children: [
      // all of your routes
    ]
 }
]
Run Code Online (Sandbox Code Playgroud)

当 MyPageRootComponent 被销毁时,您的所有服务都将被销毁。

编辑:

StackBlitz:https ://stackblitz.com/edit/lazy-load-destory-services