最近解决客户 incident,有个客户从 Spartacus 4 降级到 5.2 之后,启动 Storefront,console 遇到了一个谬误音讯:
NullInjectorError - No provider for AnonymousConsentTemplatesAdapter!
引起这个谬误音讯的场景有很多,这个 incident 最初的场景是:
以前的 module 通过 loaded for root 实现,当初改成了 loaded with module 来实现。
在Angular中,模块(Module)是组织代码的根本单元。在应用Angular模块时,有两种形式能够将模块加载到应用程序中:通过 "loaded for root"(根加载)和通过 "loaded with module"(模块加载)。这两种加载形式有一些区别,上面我将具体阐明它们,并提供一些例子来阐明其用法和成果。
- Loaded for root(根加载):
当咱们将一个模块加载为根模块时,它意味着该模块将被整个应用程序共享和应用。根模块在应用程序启动时被加载,并且在整个应用程序的生命周期中放弃加载状态。
例子:
假如咱们有一个名为 "SharedModule" 的模块,其中定义了一些罕用的组件、指令和服务,咱们心愿这些性能在整个应用程序中都可用。咱们能够将 "SharedModule" 模块加载为根模块。
// shared.module.tsimport { NgModule } from '@angular/core';import { CommonModule } from '@angular/common';import { SharedComponent } from './shared.component';import { SharedDirective } from './shared.directive';import { SharedService } from './shared.service';@NgModule({ declarations: [SharedComponent, SharedDirective], imports: [CommonModule], providers: [SharedService], exports: [SharedComponent, SharedDirective]})export class SharedModule { }
// app.module.tsimport { NgModule } from '@angular/core';import { BrowserModule } from '@angular/platform-browser';import { SharedModule } from './shared/shared.module';@NgModule({ imports: [BrowserModule, SharedModule], declarations: [AppComponent], bootstrap: [AppComponent]})export class AppModule { }
在这个例子中,咱们将 "SharedModule" 加载为根模块,并将其导入到应用程序的根模块 "AppModule" 中。这样,"SharedModule" 中定义的组件、指令和服务就能够在整个应用程序中应用,而不须要每个模块都去导入和配置它们。
- Loaded with module(模块加载):
当咱们将一个模块加载到另一个模块中时,它意味着该模块仅在该特定模块的上下文中可用。模块加载产生在特定的功能模块中,并且只在该模块及其子模块中失效。
例子:
假如咱们有一个名为 "FeatureModule" 的模块,其中蕴含了一些特定的性能组件、指令和服务,咱们心愿这些性能仅在 "FeatureModule" 及其子模块中可用。咱们能够将 "FeatureModule" 加载到另一个模块中。
// feature.module.tsimport { NgModule } from '@angular/core';import { CommonModule } from '@angular/common';import { FeatureComponent } from './feature.component';import { FeatureDirective } from './feature.directive';import { FeatureService } from './feature.service';@NgModule({ declarations: [FeatureComponent, FeatureDirective], imports: [CommonModule], providers: [FeatureService], exports: [FeatureComponent, FeatureDirective]})export class FeatureModule { }
// main.module.tsimport { NgModule } from '@angular/core';import { BrowserModule } from '@angular/platform-browser';import { FeatureModule } from './feature/feature.module';@NgModule({ imports: [BrowserModule, FeatureModule], declarations: [AppComponent], bootstrap: [AppComponent]})export class MainModule { }
在这个例子中,咱们将 "FeatureModule" 加载到另一个模块 "MainModule" 中。这样,"FeatureModule" 中定义的组件、指令和服务仅在 "MainModule" 及其子模块中可用,不会对应用程序的其余模块产生影响。
区别总结:
- "Loaded for root"(根加载)实用于那些心愿在整个应用程序中共享和应用的模块,能够被所有模块拜访和调用。
- "Loaded with module"(模块加载)实用于那些心愿在特定模块及其子模块中应用的模块,能够提供特定性能的模块封装,防止全局净化。
根加载能够使模块的性能在整个应用程序中易于拜访和应用,而模块加载能够实现模块化的性能封装和部分可用性。依据我的项目需要和代码组织的指标,能够抉择适当的加载形式来实现最佳的代码构造和可维护性。