В Angular 2 у меня есть компонент, который имеет дочерний компонент. Тем не менее, я хочу получить копию этого дочернего компонента для использования в родительском, для вызова его функций или чего-то еще.Получение ссылки на дочерний компонент в родительском компоненте
Я узнал, что могу использовать локальные переменные, и таким образом я смогу использовать компонент в шаблоне. Тем не менее, я не только использую его в шаблоне, я хочу использовать его в фактическом коде компонента.
Я нашел способ сделать это, вот ребенок код:
//our child
import {Component, OnInit, EventEmitter} from 'angular2/core'
@Component({
selector: 'my-child',
providers: [],
template: `
<div>
<h2>Child</h2>
</div>
`,
directives: [],
outputs: ['onInitialized']
})
export class Child implements OnInit{
onInitialized = new EventEmitter<Child>();
constructor() {
this.name = 'Angular2'
}
ngOnInit() {
this.onInitialized.emit(this);
}
}
Родитель:
//our root app component
import {Component} from 'angular2/core'
import {Child} from './child'
@Component({
selector: 'my-app',
providers: [],
template: `
<div>
<h2>Hello {{name}}</h2>
<my-child (onInitialized)="func($event)"></my-child>
</div>
`,
directives: [Child]
})
export class App {
constructor() {
this.name = 'Angular2'
}
func(e) {
console.log(e)
}
}
Я реализовал его здесь, в этом plunker: http://plnkr.co/edit/e3pEn9Hd54q1mijNGDpR?p=preview
Но похоже, взломать, нет ли более простого способа привязать компонент к переменной в ее родительском?
Какой конкурс на ответ ... :) – eesdil
hahahah .... вы наблюдали это, по крайней мере! – micronyks
Как уже упоминалось в ответах, вы можете использовать @ViewChild, который обсуждается в поваренной книге Component Interaction: https://angular.io/docs/ts/latest/cookbook/component-communication.html#!#parent-to -view-child –