1. ホーム
  2. angularjs

[解決済み】Angularのコールバック関数をAngularJSのように@Inputで子コンポーネントに渡す。

2022-04-01 09:40:07

質問

AngularJSには&パラメータがあり、ディレクティブにコールバックを渡すことができます(例えば AngularJSのコールバックの方法 . としてコールバックを渡すことは可能ですか? @Input Angular Componentのために(以下のようなもの)?もしそうでなければ、AngularJSが行うことに最も近いものは何でしょうか?

@Component({
    selector: 'suggestion-menu',
    providers: [SuggestService],
    template: `
    <div (mousedown)="suggestionWasClicked(suggestion)">
    </div>`,
    changeDetection: ChangeDetectionStrategy.Default
})
export class SuggestionMenuComponent {
    @Input() callback: Function;

    suggestionWasClicked(clickedEntry: SomeModel): void {
        this.callback(clickedEntry, this.query);
    }
}


<suggestion-menu callback="insertSuggestion">
</suggestion-menu>

解決方法は?

それは悪い解決策だと思います。もし、Functionをコンポーネントに渡すときに @Input() , @Output() デコレーターがあります。

export class SuggestionMenuComponent {
    @Output() onSuggest: EventEmitter<any> = new EventEmitter();

    suggestionWasClicked(clickedEntry: SomeModel): void {
        this.onSuggest.emit([clickedEntry, this.query]);
    }
}

<suggestion-menu (onSuggest)="insertSuggestion($event[0],$event[1])">
</suggestion-menu>