angular - 路由更改时销毁 Angular 服务

标签 angular angular-router angular-providers

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

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

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

...
// LazyLoaderMyPageModule
@NgModule({
  declarations: [],
  imports: [
    CommonModule,
    MyPageModule
  ]
})
export class LazyLoaderMyPageModule { }

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

我怎样才能做到这一点 ?

最佳答案

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

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

将您的延迟加载模块路由更改为:
const routes= [
 { 
    path: '',
    component: MyPageRootComponent
    children: [
      // all of your routes
    ]
 }
]

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

编辑:

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

关于angular - 路由更改时销毁 Angular 服务,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58220996/

相关文章:

javascript - 在父方法中调用 subscribe 方法

Angular 验证错误为 'ngClass',因为它不是 'div' 的已知属性。 (

Angular2父组件具有多个子组件实例

angular - 处理 Angular 5 路由器中的 URL 解析错误

javascript - Angular UrlResolver 未被自定义提供程序覆盖

angular - 在 Angular 4 上验证电子邮件

angular - 如何从子路由导航到父路由?

angular - @angular/router 将路由组件包装在 router-outlet 中以进行样式设置

angular - 为什么组件中的 ', providers: [TravelService] ' 会阻止 RXJS 行为主体跨组件共享数据?

javascript - Angular 提供者