我的 app.module.ts 中有这个:
import { BrowserModule } from '@angular/platform-browser';
import { ErrorHandler, NgModule } from '@angular/core';
import { HttpModule, Http } from '@angular/http';
import { IonicApp, IonicErrorHandler, IonicModule } from 'ionic-angular';
import { EliteApi } from '../shared/shared';
import { MyApp } from './app.component';
import { MyTeams, Tournaments, TeamDetails, Teams, TeamHome, Standings } from '../pages/pages';
import { StatusBar } from '@ionic-native/status-bar';
import { SplashScreen } from '@ionic-native/splash-screen';
@NgModule({
declarations: [
MyApp,
MyTeams,
TeamDetails,
Tournaments,
Teams,
TeamHome,
Standings
],
imports: [
BrowserModule,
IonicModule.forRoot(MyApp),
HttpModule
],
bootstrap: [IonicApp],
entryComponents: [
MyApp,
MyTeams,
TeamDetails,
Tournaments,
Teams,
TeamHome,
Standings
],
providers: [
HttpModule,
StatusBar,
SplashScreen,
{ provide: ErrorHandler, useClass: IonicErrorHandler },
EliteApi
]
})
export class AppModule { }
目前我的declarations
和entryComponents
完全一样。它们包含我为我的应用程序构建的所有页面/组件。如果我从任何属性中删除任何条目,我会在 angular2 中收到错误。
我的问题是,如果它们始终相同,那么对这些属性的需求是什么?我想我肯定在这里遗漏了一些要点。 entryComponents 和 declarations 何时会彼此不同?
最佳答案
entryComponents
数组用于定义 仅 在 html 中找不到并使用 ComponentFactoryResolver
动态创建的组件。 Angular 需要这个提示来找到它们并编译。所有其他组件应仅列在声明数组中。
关于angular - declarations 和 entryComponents 有什么区别,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43815995/