この記事では、Angular におけるコンポーネント通信を理解し、親コンポーネントが子コンポーネントに通信する方法、子コンポーネントが親コンポーネントに通信する方法を紹介します。 !

コンポーネントは完全に独立しているため、相互間のデータは共有されません。コンポーネント間でデータを共有したい場合は、コンポーネント間の通信を実装する必要があります。 [関連チュートリアルの推奨事項: "angular チュートリアル"]
コンポーネント間の通信
親コンポーネントは子コンポーネントと通信します#ng6 は ts に基づいて実装されているため、通信データは型を定義する必要があります (内部構造の理解、メモリ領域の割り当て)
親コンポーネントは子コンポーネントと通信します。 コンポーネント通信では、サブコンポーネントが受信側となるため、入力スループットが使用されます。 #親コンポーネントからサブコンポーネントへの通信は、次のように分割されます。 6 つのステップ最初のステップ 親コンポーネント テンプレートで、データを子コンポーネントに渡します。データが動的に可変である場合は、[] 構文のシュガー
を使用できます。2 番目のステップ データ モデル クラスを定義します (データが非常に単純な場合は、このステップを省略できます)
ng ディレクティブを使用してモデル クラスを定義することもできますng class 类名
サブコンポーネントにモデル クラスを導入します
4 番目のステップ ステップ サブコンポーネントで、スループット入力を導入します
5 番目のステップ スループットを通じてデータを受信するには 2 つの方法があります
最初の方法は、入力スループット アノテーション クラスを通じてデータを受信することです。
@Input() 数据名称: 模型类;
アノテーション クラス内: 入力:
[属性データ]コンポーネント内: 属性データ: モデルclass;
ステップ 6 データを使用する: データはコンポーネント自体に追加されるため、コンポーネントまたはテンプレートのどちらでも使用できます。 #例:
// 4 引入吞吐器
import { Component, OnInit, Input } from '@angular/core';
// 3 引入模型类
import { Data } from '../../models/data';
@Component({
selector: 'app-inputs',
templateUrl: './inputs.component.html',
styleUrls: ['./inputs.component.css'],
// 5 通过元信息接收
inputs: ['color', 'data']
})
export class InputsComponent implements OnInit {
// 5 接收数据
// @Input() data: Data;
// @Input() color: string;
// 声明类型
data: Data;
color: string;
constructor() {
// 6 组件中使用
console.log(this)
}
ngOnInit() {
}
}子コンポーネントと親コンポーネント間の通信
子コンポーネントと親コンポーネント間の通信は、カスタム イベントに基づいています。サブコンポーネントの場合はパブリッシャーであるため、Ouput スループットを使用します。サブコンポーネントと親コンポーネント間の通信を実装するには 6 つの手順があります
最初のステップ親コンポーネント テンプレートで、DOM イベントをシミュレートし、親コンポーネント メソッドを子コンポーネント要素にバインドし、() 構文シュガーを使用します。 例: (demo)="dealDemo($event) "
データを渡すために、$eventを追加します。
2番目のステップサブコンポーネントに、スループットの出力を導入します。
3番目のステップステップサブコンポーネントで、EventEmitter イベント モジュールを導入します#ステップ 4
サブコンポーネントのイベント オブジェクトを作成するには 2 つの方法があります##最初の方法は出力スループットを介して登録します
@Output() 属性名称 = new EventEmitter()
コンポーネントで、イベント オブジェクトを作成します。
属性名 = new EventEmitter() ステップ 5 子コンポーネントで、イベント オブジェクトの Emit メソッドを通じてメッセージをパブリッシュします。パラメータは渡されたデータです。
ステップ 6 親コンポーネントで、親コンポーネント メソッドを介して受信しますサブコンポーネントによって渡されるデータ
import { Component, OnInit, Output, EventEmitter } from '@angular/core';
@Component({
selector: 'app-outputs',
templateUrl: './outputs.component.html',
styleUrls: ['./outputs.component.css'],
// 元信息注册事件对象
outputs: ['sendMessage']
})
export class OutputsComponent implements OnInit {
// 4 注册事件对象
// @Output() sendMessage = new EventEmitter();
// 实例化
sendMessage = new EventEmitter();
constructor() { }
ngOnInit() {
}
// 事件回调函数
demo() {
// console.log(111, this)
// 5 点击按钮的时候,向父组件发布消息
this.sendMessage.emit({
msg: 'hello菜鸟',
color: 'red'
})
}
}プログラミング関連の知識の詳細については、プログラミング入門を参照してください。 !
以上がAngular の親コンポーネントと子コンポーネントの間で通信する方法についての簡単な説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。