- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我将较大的应用程序划分为模块(功能模块、核心模块和共享模块)。我使用的是 Angular Material,因此我导入了 BrowserAnimationsModule
。我将它放在共享模块中并且一切正常,但是当我想延迟加载一些功能模块时出现问题 - 然后我有关于 BrowserModules 的双重导入错误。我知道 BrowserAnimationsModule 应该由核心模块导入,但是当我尝试这样做时,出现以下错误:
Uncaught Error: Template parse errors:
Can't bind to 'ngForOf' since it isn't a known property of 'mat-option'.
1. If 'mat-option' is an Angular component and it has 'ngForOf' input, then verify that it is part of this module.
2. If 'mat-option' is a Web Component then add 'CUSTOM_ELEMENTS_SCHEMA' to the '@NgModule.schemas' of this component to suppress this message.
3. To allow any property add 'NO_ERRORS_SCHEMA' to the '@NgModule.schemas' of this component. ("' | translate}}" (change)="change()" [(ngModel)]="actualFilter" name="food">
<mat-option [ERROR ->]*ngFor="let filterColumn of displayedColumns" [value]="filterColumn">
{{filterColumn | t"): ng:///ChargesModule/ChargesComponent.html@9:22
Property binding ngForOf not used by any directive on an embedded template. Make sure that the property name is spelled correctly and all directives are listed in the "@NgModule.declarations". ("COLUMNFILTER' | translate}}" (change)="change()" [(ngModel)]="actualFilter" name="food">
[ERROR ->]<mat-option *ngFor="let filterColumn of displayedColumns" [value]="filterColumn">
{{filt"): ng:///ChargesModule/ChargesComponent.html@9:10
下面我介绍模块:应用程序模块.ts:
@NgModule({
declarations: [
AppComponent
],
imports: [
BrowserModule,
HomeModule,
ChargesModule,
ModeratorPanelModule,
CoreModule
],
providers: [],
bootstrap: [AppComponent]
})
export class AppModule { }
核心模块.ts:
@NgModule({
imports: [
HttpModule,
HttpClientModule,
AppRoutingModule,
SharedModule,
BrowserAnimationsModule
],
declarations: [
SidenavComponent,
HeaderComponent,
ErrorPageComponent,
PageNotFoundComponent,
LoginComponent,
UpdatePanelComponent,
DialogConfirmCancelComponent,
ConfirmMessageComponent,
],
exports: [
HttpModule,
HttpClientModule,
SharedModule,
HeaderComponent,
SidenavComponent,
AppRoutingModule,
BrowserAnimationsModule
],
providers: [
AuthService, AuthGuard, HttpAuthService, DictionariesService,
DictionaryItemFactory, CanDeactivateGuard, { provide: MatPaginatorIntl, useClass: CustomPaginator }
],
entryComponents: [DialogConfirmCancelComponent, ConfirmMessageComponent]
})
export class CoreModule { }
共享模块.ts:
export function HttpLoaderFactory(http: HttpClient) {
return new TranslateHttpLoader(http);
}
@NgModule({
imports: [
CommonModule,
MaterialModule,
FlexLayoutModule,
CdkTableModule,
FormsModule,
NgbModule.forRoot(),
TimepickerModule.forRoot(),
TranslateModule.forRoot({
loader: {
provide: TranslateLoader,
useFactory: HttpLoaderFactory,
deps: [HttpClient]
}
})
],
exports: [
NgbModule,
TimepickerModule,
TranslateModule,
CurrenciesComponent,
MaterialModule,
FlexLayoutModule,
CdkTableModule,
FormsModule,
DropDownListComponent,
DictionariesComponent
],
declarations: [
DictionariesComponent,
DropDownListComponent
],
providers: []
})
export class SharedModule { }
在 MaterialModule 中,我已经将所有 Material 模块与 CommonModule 一起导入。
最佳答案
如果你遇到类似这样的错误
Can't bind to 'ngForOf' since it isn't a known property
那么你应该意识到它:
与未声明的@Input
有关;
或者您对@NgModule
配置有一些问题
由于 ngForOf
是一个内置指令,让我们分析一下您的 @NgModule
配置有什么问题。
首先我们需要确定这个错误是从哪里来的。从报错信息中很容易看出:
{{filterColumn | t"): ng:///ChargesModule/ChargesComponent.html@9:22
应该清楚的是,我们收到了 ChargesComponent
的错误,它是 ChargesModule
的一部分。我相信 ChargesModule
声明看起来像:
charges.module.ts
@NgModule({
imports: [
SharedModule,
...
],
declarations: [
ChargesComponent,
...
]
})
export class ChargesModule {}
现在,如果您还没有阅读我之前的回答 Angular 2 Use component from another module我强烈建议你这样做。确保您了解如何在其他模块中使用一个组件/指令/管道。如果您这样做了,那么只需从 SharedModule
导出 CommonModule
,如果您仍然有疑问,请继续阅读...
这里的主要规则是
由于我们需要在 ChargesComponent
模板中使用 ngForOf 指令,它是 ChargesModule 的一部分,因此该指令应该是可传递 ChargesModule 中指令的一部分。
这些指令是如何收集的?
ChargesModule.directives
+
exported directives from imported @NgModules
||
ChargesModule.transitiveModule.directives
乍一看,我们会在 ChargesModule
声明数组中声明 ngForOf
指令,但 ngForOf
已经在 CommonModule
中声明由于指令只能是一个模块的一部分,我们不能那样做。
因此继续在导入的@NgModules
中寻找ngForOf
指令。好吧,我们导入了 SharedModule
让我们看看它导出了哪些指令:
shared.module.ts
@NgModule({
...,
exports: [
NgbModule,
TimepickerModule,
TranslateModule,
CurrenciesComponent,
MaterialModule,
FlexLayoutModule,
CdkTableModule,
FormsModule,
DropDownListComponent,
DictionariesComponent
]
})
export class SharedModule { }
SharedModule
导出所有指令
从@NgModules
导出
NgbModule,
TimepickerModule,
TranslateModule,
MaterialModule,
FlexLayoutModule,
CdkTableModule,
FormsModule
这意味着如果 NgbModule 有导出指令,那么它们将被添加到 SharedModule 的导出指令中。
或者只是包含在exports
数组中的指令
CurrenciesComponent,
DropDownListComponent,
DictionariesComponent
因为我们在这里没有看到CommonModule
,我们可以假设我们会得到错误Can't bind to 'ngForOf'
要解决这个问题,我们必须将 CommonModule
添加到 exports 数组中,所有这些都应该按预期工作。
好问题是
However, I do not understand why this problem occured only after moving of BrowserAnimationsModule from Shared to Core module. Can you explain that?
如果不知道 BrowserAnimationsModule
长什么样,就很难理解。让我们通过查看source code来获得启迪:
@NgModule({
exports: [BrowserModule],
providers: BROWSER_ANIMATIONS_PROVIDERS,
})
export class BrowserAnimationsModule {
}
并查看BrowserModule :
@NgModule({
...
exports: [CommonModule, ApplicationModule]
})
export class BrowserModule {
很明显,如果我们从 SharedModule
中导出 BrowserAnimationsModule
模块,我们也会从 CommonModule
中导出指令,因为:
SharedModule.transitiveModule.directives
/\
||
BrowserAnimationsModule exports
/\
||
BrowserModule that exports
/\
||
CommonModule
因此,在将 BrowserAnimationModule
移动到 CoreModule
之后,您的 SharedModule
不再导出 ngForOf
指令,这就是您的原因出现错误。
关于angular - BrowserAnimationsModule 在核心模块中导入时不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46911583/
我正在尝试在项目中学习和添加 Angular 国际化。我只能理解 Angular 文档 (https://angular.io/guide/i18n-overview) 的编译时翻译。 我需要这样的东
在我的 Angular 应用程序中,基于登录用户,我想通过显示/隐藏不同的菜单项或允许/禁止某些路由来授予或限制功能。 目前成功登录后,我的 .NET Core API 会返回一个 JWT token
我是 Angular 的新手,目前我已经看过 angular.io 网站提供的一些示例。但是在component decorator在文档中的解释,它指出 Angular components are
这里是service employee-service.service.ts的代码 import { Injectable } from '@angular/core'; import { HttpC
我目前正在使用@angular/http URLSearchParams 类来检索 URL 参数。在 Angular 5 中,注意到这已被弃用,但我没有看到以我当前使用的方式替换 URLSearchP
我目前正在使用@angular/http URLSearchParams 类来检索 URL 参数。在 Angular 5 中,注意到这已被弃用,但我没有看到以我当前使用的方式替换 URLSearchP
如何正确安装 PUG/JADE 到 Angular 2 或更高版本 这样在工作和 AOT 和 JiT 的同时 工作单元和集成测试 并且在创建每个新组件时不会受到太多影响 最佳答案 我看到了很多解决方案
我的 Angular 12 应用程序中有一些通用组件,我计划将其创建为一个 Angular 库,以便其他应用程序也可以使用它。我们有一些应用程序在较低版本的 angular(例如 angular 8/
tl;dr; ng build 删除了包含我编译的自定义库的/dist 文件夹。这会使我项目代码中对该库的所有引用无效,从而导致 ng build 最终失败。我做错了什么? 我关注了documenta
我正在将一些“遗留”(非 typescript )js 库导入到我的 Angular SPA 中。 通常我只是从 cdn 添加一个负载到 index.html 就像: 在 Angular 分量中我只
我有这个 angular 应用程序,它基本上使用了库的概念。 我有 2 个名为 的库Lib1 和 lib2 根据他们所服务的微服务分组。 现在我将这些库导入主应用程序,即 应用1 事情一直到现在。 现
我在我的项目中启用了 angular Universal。我现在想完全删除它。我试图删除以下文件 /server.ts /webpack.server.config.js /src/tsconfig.
我已经有一个 AuthService 在登录时对用户进行身份验证,并且 AuthGuard 在未登录的情况下阻止访问。 某些页面我通过 UserProfile/Role 限制访问,但现在我需要阻止页面
我正在尝试使用 angular、TypeORM、SQLite 和其他组件作为 webpack 构建 Electron 应用程序。 我从在 GitHub 上找到的示例开始我的开发:https://git
我在从 Angular 8 更新到 9 并运行时遇到以下错误 ng 更新@angular/material: Package "@angular/flex-layout" has an incompa
我正在尝试使用 Angular 9,我想创建一个项目,然后创建一个库项目并开始向其中添加我想稍后在 GitHub 上发布的通用模块,并在我的本地使用这些库项目。 相关依赖如下: Angular CLI
我正在尝试使用 Angular 9,我想创建一个项目,然后创建一个库项目并开始向其中添加我想稍后在 GitHub 上发布的通用模块,并在我的本地使用这些库项目。 相关依赖如下: Angular CLI
我正在我的 h1 元素“之前”创建一个小的程式化三 Angular 形图案,但我无法正确地圆 Angular 。右上角没问题,但其他两个有剪裁问题。 这是输出以及形状的放大图像: 使用的代码如下: h
我有一个 Angular 元素,带有自定义标记名 - fancy-button。如何将 fancy-button 嵌入 Angular 应用程序? 我已经尝试了以下方法,但都没有用 - 在 index
我已将我的项目从 angular 5.2.9 升级到 angular 6.0.0-rc.5。 除了包路径中的几个快速 RxJS 修复外,一切看起来都不错。(此链接非常有用:Want to upgrad
我是一名优秀的程序员,十分优秀!