angularjsangulartypescript

Angular pass callback function to child component as @Input similar to AngularJS way


AngularJS has the & parameters where you could pass a callback to a directive (e.g AngularJS way of callbacks. Is it possible to pass a callback as an @Input for an Angular Component (something like below)? If not what would be the closest thing to what AngularJS does?

@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>

Solution

  • I think that is a bad solution. If you want to pass a Function into component with @Input(), @Output() decorator is what you are looking for.

    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>