角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);
}
}
親: http://plnkr.co/edit/e3pEn9Hd54q1mijNGDpR?p=preview
しかし、それは:私はこのplunkerにここでそれを実現し
//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)
}
}
ハックのように思えますが、コンポーネントを親の変数にアタッチする簡単な方法はありませんか?
何の答えに競争... :) – eesdil
HAHAHAH ....あなたは、少なくともそれを観察しています! – micronyks
回答で既に述べたように、コンポーネントインタラクションのクックブックで説明している@ViewChildを使用できます。https://angular.io/docs/ts/latest/cookbook/component-communication.html#!#parent-to -view-child –