在Angular 7中,如果你的单例服务在路由后不起作用,可能是因为路由导航会销毁当前组件并创建新的组件实例。这导致了原来的单例服务实例被销毁并重新创建,从而失去了单例服务的作用。
解决这个问题的一种方法是使用一个根级别的服务提供商,这样服务的实例将在整个应用程序中是唯一的。以下是一个示例:
AppService
的根级别服务import { Injectable } from '@angular/core';
@Injectable({
providedIn: 'root'
})
export class AppService {
// 在这里定义你的服务逻辑
}
import { NgModule } from '@angular/core';
import { AppService } from './app.service';
@NgModule({
providers: [AppService]
})
export class AppModule { }
import { Component } from '@angular/core';
import { AppService } from './app.service';
@Component({
selector: 'app-my-component',
template: `...`,
})
export class MyComponent {
constructor(private appService: AppService) {
// 使用appService进行逻辑操作
}
}
通过将服务注册为根级别的提供者,你将获得一个全局的单例服务实例,无论路由如何变化,都会保持一致。