我是Angular2的新手。我试图创建一个组件,但显示一个错误。
这是app.component.ts文件。
import { Component } from '@angular/core';
import { MyComponentComponent } from './my-component.component';
@Component({
selector: 'my-app',
template: `
<h1>Hello {{name}}</h1>
<h4>Something</h4>
<my-component></my-component>
`,
directives: [MyComponentComponent]
})
export class AppComponent { name = 'Sam' }
这是我要创建的组件。
import { Component } from '@angular/core';
@Component({
selector: 'my-component',
template: `
<p>This is my article</p>
`
})
export class MyComponentComponent {
}
显示两个错误:
如果my-component是一个Angular组件,那么验证它是否是这个模块的一部分。
如果my-component是Web组件,那么将CUSTOM_ELEMENTS_SCHEMA添加到@NgModule中。模式来抑制此消息。
请帮助。
我使用的是Angular v11,在尝试延迟加载组件(await import('./my-component.component'))时遇到了这个错误,即使导入和导出设置正确。
我最终发现解决方案是删除单独的专用模块的文件,并将模块内容移动到组件文件本身中。
rm -r my-component.module.ts
并在my-component中添加模块。Ts(同一文件)
@Component({
selector: 'app-my-component',
templateUrl: './my-component.page.html',
styleUrls: ['./my-component.page.scss'],
})
export class MyComponent {
}
@NgModule({
imports: [CommonModule],
declarations: [MyComponent],
})
export class MyComponentModule {}
不要导出默认的MyComponentComponent类!
与标题相关的问题,如果不是具体的问题:
我不小心做了一个…
export default class MyComponentComponent {
... 这也把事情搞砸了。
为什么?当我把它放入声明时,VS Code添加了导入到我的模块,但不是…
import { MyComponentComponent } from '...';
它有
import MyComponentComponent from '...';
这并没有向上映射到下游,假设因为它没有在默认导入的任何地方“真正”命名。
export class MyComponentComponent {
没有违约。利润。
你是否像这样在app.module.ts中导入它并删除指令位:-
@NgModule({
bootstrap: [AppComponent],
imports: [MyComponentModule],// or whatever the name of the module is that declares your component.
declarations: [AppComponent],
providers: []
})
export class AppModule {}
你的MyComponentModule应该是这样的
@NgModule({
imports: [],
exports: [MyComponentComponent],
declarations: [MyComponentComponent],
providers: [],
})
export class MyComponentModule {
}