Angular 6: компонент общего доступа между функциональными модулями не работает
Я создал 2 функциональных модуля (PagesSharedModule
& HomeModule
).
Сейчас я пытаюсь использовать экспортированный компонент из PagesSharedModule
внутри шаблона компонента из HomeModule
& Я получаю эту ошибку:
ERROR Error: Uncaught (in promise): Error: Template parse errors: 'app-main-menu' is not a known element:
1. If 'app-main-menu' is an Angular component, then verify that it is part of this module.
2. If 'app-main-menu' is a Web Component then add 'CUSTOM_ELEMENTS_SCHEMA' to the '@NgModule.schemas' of this component to suppress this message. ("[ERROR
->]<app-main-menu></app-main-menu>"): ng:///HomeModule/HomeComponent.html@0:0 Error: Template parse errors: 'app-main-menu' is not a known element:
1. If 'app-main-menu' is an Angular component, then verify that it is part of this module.
2. If 'app-main-menu' is a Web Component then add 'CUSTOM_ELEMENTS_SCHEMA' to the '@NgModule.schemas' of this component to suppress this message. ("[ERROR
->]<app-main-menu></app-main-menu>"): ng:///HomeModule/HomeComponent.html@0:0
at syntaxError (compiler.js:215)
at TemplateParser.push../node_modules/@angular/compiler/fesm5/compiler.js.TemplateParser.parse (compiler.js:14687)
at JitCompiler.push../node_modules/@angular/compiler/fesm5/compiler.js.JitCompiler._parseTemplate (compiler.js:22687)
at JitCompiler.push../node_modules/@angular/compiler/fesm5/compiler.js.JitCompiler._compileTemplate (compiler.js:22674)
at compiler.js:22617
at Set.forEach (<anonymous>)
at JitCompiler.push../node_modules/@angular/compiler/fesm5/compiler.js.JitCompiler._compileComponents (compiler.js:22617)
at compiler.js:22527
at Object.then (compiler.js:206)
at JitCompiler.push../node_modules/@angular/compiler/fesm5/compiler.js.JitCompiler._compileModuleAndComponents (compiler.js:22526)
at syntaxError (compiler.js:215)
at TemplateParser.push../node_modules/@angular/compiler/fesm5/compiler.js.TemplateParser.parse (compiler.js:14687)
at JitCompiler.push../node_modules/@angular/compiler/fesm5/compiler.js.JitCompiler._parseTemplate (compiler.js:22687)
at JitCompiler.push../node_modules/@angular/compiler/fesm5/compiler.js.JitCompiler._compileTemplate (compiler.js:22674)
at compiler.js:22617
at Set.forEach (<anonymous>)
at JitCompiler.push../node_modules/@angular/compiler/fesm5/compiler.js.JitCompiler._compileComponents (compiler.js:22617)
at compiler.js:22527
at Object.then (compiler.js:206)
at JitCompiler.push../node_modules/@angular/compiler/fesm5/compiler.js.JitCompiler._compileModuleAndComponents (compiler.js:22526)
at resolvePromise (zone.js:814)
at resolvePromise (zone.js:771)
at zone.js:873
at ZoneDelegate.push../node_modules/zone.js/dist/zone.js.ZoneDelegate.invokeTask (zone.js:421)
at Object.onInvokeTask (core.js:3751)
at ZoneDelegate.push../node_modules/zone.js/dist/zone.js.ZoneDelegate.invokeTask (zone.js:420)
at Zone.push../node_modules/zone.js/dist/zone.js.Zone.runTask (zone.js:188)
at drainMicroTaskQueue (zone.js:595)
Если это имеет какое-то значение, HomeModule
является маршрутизируемым модулем с отложенной загрузкой
Мой код:
SRC / приложение / страницы / страница-Shared / страница-shared.module.ts
import { NgModule } from '@angular/core';
import { CommonModule } from '@angular/common';
import { MainMenuComponent } from './main-menu/main-menu.component';
@NgModule({
imports: [
CommonModule
],
declarations: [
MainMenuComponent
],
exports: [
MainMenuComponent
]
})
export class PagesSharedModule { }
ЦСИ / приложение / страницы / страница-Shared / главное меню / Основной-menu.component.ts
import { Component, OnInit } from '@angular/core';
@Component({
selector: 'app-main-menu',
templateUrl: './main-menu.component.html',
styleUrls: ['./main-menu.component.scss']
})
export class MainMenuComponent implements OnInit {
constructor() { }
ngOnInit() { }
}
SRC / приложения / страницы / дома / home.module.ts
import { NgModule } from '@angular/core';
import { CommonModule } from '@angular/common';
import { HomeComponent } from './home.component';
import { HomeRoutingModule } from './home-routing.module';
import { PagesSharedModule } from 'src/app/pages/pages-shared/pages-shared.module';
@NgModule({
imports: [
CommonModule,
HomeRoutingModule,
PagesSharedModule
],
declarations: [
HomeComponent
]
})
export class HomeModule { }
ЦСИ / приложение / страницы / главная / home.component.html
<app-main-menu></app-main-menu>
SRC / приложение / страницы / страница-routing.module.ts
...
{
path: '',
component: PagesComponent,
children: [
{
path: '',
pathMatch: 'full',
loadChildren: './home/home.module#HomeModule'
},
{
path: 'about',
pathMatch: 'full',
loadChildren: './content/content.module#ContentModule'
},
{ path: '**', component: PageNotFoundComponent }
]
},
...
SRC / приложение / страницы / дома / дом-routing.module.ts
{
path: '',
pathMatch: 'full',
component: HomeComponent
}
Что я делаю неправильно?
Благодарю.
1 ответ
ОБНОВИТЬ:
Невероятно!!!
Я остановил угловой CLI и снова обслужил, и теперь все работает без каких-либо изменений в коде.
Оставьте эту заметку здесь на случай, если кто-то еще столкнется с той же проблемой...