在Angular 13中,你可以使用useClass来替换APP_INITIALIZER中的函数。使用useClass可以更容易地测试你的应用程序,也可以更好地遵循依赖注入模式。
以下是一个使用useClass的示例代码:
import { Injectable } from '@angular/core';
@Injectable() export class MyService { init() { // 初始化代码 } }
import { NgModule, APP_INITIALIZER } from '@angular/core'; import { MyService } from './my.service';
function initApp(myService: MyService) { return () => myService.init(); }
@NgModule({ declarations: [/* ... /], imports: [/ ... /], providers: [ MyService, { provide: APP_INITIALIZER, useFactory: initApp, deps: [MyService], multi: true } ], bootstrap: [/ ... */] }) export class AppModule { }
在这个例子中,我们创建了一个MyService类来初始化我们的应用程序,并将它与一个initApp()函数结合使用,来替代APP_INITIALIZER。通过将MyService类提供给initApp()函数,我们可以快速地将MyService类中的逻辑添加到我们的应用程序中。
可以在其他地方注入MyService并使用它的函数进行操作。这使得应用程序更加可测试和可管理。