При создании приложения angular 2 для производства мы используем
ng build --prod --w --aot
Но наши макетные услуги также попадают в связку и минимизируются, вероятно, потому что у нас
import {XMockService} from "./xxx-mock.service";
что не позволяет дрожанию дерева отбрасывать неиспользуемую службу. Вот наш упрощенный app.module.ts, который условно ленивает загрузку макетной службы, когда environment.mock = true
Я бы предположил, что это распространенный сценарий, но я не могу найти ответы на него.
app.module.ts:
import {BrowserModule} from "@angular/platform-browser";
import {NgModule} from "@angular/core";
import {FormsModule} from "@angular/forms";
import {HttpModule} from "@angular/http";
import {AppComponent} from "./app.component";
import {environment} from "../environments/environment";
import {XService} from "./xxx.service";
import {XMockService} from "./xxx-mock.service";
let importedModules: Array<any> = [
XService
];
if (environment.mock) {
importedModules.push(
{provide: XService, useClass: XMockService}
);
} else {
importedModules.push(
XService
);
}
@NgModule({
declarations: [
AppComponent
],
imports: [
BrowserModule,
FormsModule,
HttpModule
],
providers: importedModules,
bootstrap: [AppComponent]
})
export class AppModule {}