我是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中。模式来抑制此消息。

请帮助。


当前回答

不要导出默认的MyComponentComponent类!

与标题相关的问题,如果不是具体的问题:

我不小心做了一个…

export default class MyComponentComponent {

... 这也把事情搞砸了。

为什么?当我把它放入声明时,VS Code添加了导入到我的模块,但不是…

import { MyComponentComponent } from '...';

它有

import MyComponentComponent from '...';

这并没有向上映射到下游,假设因为它没有在默认导入的任何地方“真正”命名。

export class MyComponentComponent {

没有违约。利润。

其他回答

这可能是晚了,但我得到了同样的问题,但我重建(ng serve)项目和错误已经消失了

上述错误从Angular 9开始也会产生。 这本书提供了一个解决方案。

该警告建议使用CUSTOM_ELEMENTS_SCHEMA,但所讨论的元素不是Web组件。我们希望Angular直接忽略这些元素。因此,我们使用NO_ERRORS_SCHEMA,“允许任何元素上的任何属性的模式”。 向各自的.spec文件添加模式:[NO_ERRORS_SCHEMA]可以消除错误。

await TestBed.configureTestingModule({
  declarations: [MyComponent],
  schemas: [NO_ERRORS_SCHEMA],
}).compileComponents();

检查父组件在哪个模块中被声明…

如果父组件定义在共享模块中,那么子模块也必须定义在共享模块中。

父组件可以在共享模块中声明,而不是在基于文件目录结构/命名的逻辑模块中声明,即使在我的例子中,Angular CLI也将它添加到错误的模块中。

这可能是html标签组件的名称

你可以在html中使用这样的东西<mycomponent></mycomponent>

你必须使用这个<app-mycomponent></app-mycomponent>

不要导出默认的MyComponentComponent类!

与标题相关的问题,如果不是具体的问题:

我不小心做了一个…

export default class MyComponentComponent {

... 这也把事情搞砸了。

为什么?当我把它放入声明时,VS Code添加了导入到我的模块,但不是…

import { MyComponentComponent } from '...';

它有

import MyComponentComponent from '...';

这并没有向上映射到下游,假设因为它没有在默认导入的任何地方“真正”命名。

export class MyComponentComponent {

没有违约。利润。