주입과 함께 각도 2 데모를하고 있는데 내 CustomDirective를 입력 요소로 사용할 수 없다는 오류가 발생합니다. 그래서지시문을 각도 2의 입력 구성 요소로 사용할 수 없습니다.
, 내 NgModule
import {platformBrowserDynamic} from '@angular/platform-browser-dynamic';
import AppComponent from './app.component';
import {NgModule} from "@angular/core";
@NgModule({
declarations: [AppComponent],
bootstrap:[AppComponent]
})
export class AppModule{}
const platform = platformBrowserDynamic();
platform.bootstrapModule(AppModule);
AppComponent :
import {Component} from '@angular/core';
import {TIMER_DIRECTIVES} from './timer/timer';
import {TASK_DIRECTIVES} from './tasks/tasks';
import {SHARED_PROVIDERS} from './shared/shared';
@Component({
selector: 'tomato-app',
entryComponents: [TIMER_DIRECTIVES,TASK_DIRECTIVES],
providers: [SHARED_PROVIDERS],
template: `
<nav class="navbar navbar-default navbar-static-top">
<div class="container">
<div class="navbar-header">
<strong class="navbar-brand">Tomato App</strong>
</div>
</div>
</nav>
<tomato-timer-widget></tomato-timer-widget>
<tomato-tasks></tomato-tasks>`
})
export default class AppComponent{}
그리고 사용자 정의 지시어 자체 : 내가 잘못 AppComponent에 entryComponents을 사용하고 있음을
import {Task} from '../shared/shared'
import {Input, HostListener, Directive} from '@angular/core';
@Directive({
selector: '[task]'
})
export default class TaskTooltipDirective {
private defaultTooltipText: string;
@Input() task: Task;
@Input() taskTooltip: any;
@HostListener('mouseover')
onMouseOver() {
if (!this.defaultTooltipText && this.taskTooltip) {
this.defaultTooltipText = this.taskTooltip.innerText;
}
this.taskTooltip.innerText = this.task.name;
}
@HostListener('mouseout')
onMouseOut() {
if (this.taskTooltip) {
this.taskTooltip.innerText = this.defaultTooltipText;
}
}
}
문제입니다. 사용자 지정 지시문을 연결하려면 어떻게해야합니까?
루트 NgModule에서'entryComponents : [AppComponent]'를 추가하십시오. docs는 entryComponents에 AppComponent를 추가 할 필요가 없다고하지만 여분의 중복만으로 코드를 손상시키지 않는다고 말합니다 –
이 문제가 해결 되었습니까? – echonax
불행히도 nope –