Rumah > hujung hadapan web > tutorial js > Perbincangan ringkas mengenai 5 kaedah komunikasi antara komponen Sudut

Perbincangan ringkas mengenai 5 kaedah komunikasi antara komponen Sudut

青灯夜游
Lepaskan: 2021-08-16 10:04:04
ke hadapan
2698 orang telah melayarinya

Bagaimana untuk berkomunikasi antara komponen Sudut? Artikel berikut akan memperkenalkan kepada anda 5 kaedah komunikasi antara komponen Angular Jika perlu, anda boleh merujuknya~

Perbincangan ringkas mengenai 5 kaedah komunikasi antara komponen Sudut

komponen dibina oleh. Unit sudut, untuk memastikan data boleh dipindahkan ke sana ke mari antara komponen dalam projek, Angular merangkum beberapa kaedah yang boleh mencapai komunikasi antara komponen. [Tutorial berkaitan yang disyorkan: "tutorial sudut"]

1. Komponen induk menghantar data kepada komponen anak melalui pengikatan input

Komponen induk

induk.komponen.ts

age = 18;
name = '  xiaoming '
Salin selepas log masuk
induk.komponen.html

<app-child-1 [age]="age" [name]="name"></app-child-1>
Salin selepas log masuk

Komponen anak

child1.component.ts

@Input() age!: number;
Salin selepas log masuk

Pintasan perubahan dalam nilai atribut input

1 untuk memintas perubahan nilai dalam komponen induk dan mengambil tindakan.

child1.component.ts

@Input()
set name(name: string) {
    this._name = name.trim();
}
private _name: string;
Salin selepas log masuk
2 Gunakan fungsi cangkuk ngOnChanges() untuk memantau perubahan dalam nilai atribut input dan bertindak balas. Kaedah ini lebih sesuai daripada menggunakan penetap sifat apabila sifat input interaktif berbilang perlu dipantau.

child1.component.ts

ngOnChanges(changes: SimpleChanges): void {
    console.log(changes);
}
Salin selepas log masuk
Kita boleh mengetahui tentang sifat berkaitan SimpleChange melalui fail penerangan jenis yang disediakan secara rasmi oleh sudut:

Perbincangan ringkas mengenai 5 kaedah komunikasi antara komponen Sudut

Perbincangan ringkas mengenai 5 kaedah komunikasi antara komponen Sudut

2 Komponen induk mendengar peristiwa komponen anak dan memperoleh nilai yang dihantar oleh komponen anak kepada komponen induk

Komponen anak mendedahkan atribut Pemancar Acara (dengan @ penghias Output), apabila peristiwa berlaku, komponen anak menggunakan atribut ini untuk memancarkan peristiwa untuk memancarkan nilai kepada komponen induk. Komponen induk mengikat pada sifat peristiwa ini dan bertindak balas apabila peristiwa itu berlaku.

Komponen kanak-kanak

kanak-kanak1.komponen.ts

@Output() voted = new EventEmitter<boolean>();
emitValue(): void {
    this.voted.emit(true);
}
Salin selepas log masuk
kanak-kanak1.komponen.html

<button (click)="emitValue()">Click</button>
Salin selepas log masuk

Komponen induk

induk.komponen.html

<app-child-1 [age]="age" [name]="name" (voted)="getChildParam($event)"></app-child-1>
Salin selepas log masuk
induk.komponen.ts

getChildParam(value: boolean): void {
    console.log(value); // true
}
Salin selepas log masuk

3 (#varibleName) Baca sifat komponen anak dan panggil kaedah komponen anak dalam templat

Komponen anak

child1.component.ts

address = &#39;Shanghai&#39;;
setAddress(address: string): void {
    this.address = address;
}
Salin selepas log masuk

Komponen induk

parent.component.html

<app-child-1 [age]="age" [name]="name" (voted)="getChildParam($event)" #child1Component></app-child-1>
<div>{{child1Component.address}}</div>
<button (click)="child1Component.setAddress(&#39;Beijing&#39;)">Click</button>
Salin selepas log masuk
Keterbatasan: Sambungan komponen induk-anak mesti semuanya berada dalam komponen induk Teruskan dalam templat. Jika kelas komponen induk perlu membaca nilai sifat komponen anak atau memanggil kaedah komponen anak, ia tidak boleh menggunakan kaedah pembolehubah tempatan.

4. Komponen induk memanggil @ViewChild

Apabila kelas komponen induk perlu membaca nilai sifat komponen anak atau memanggil kaedah anak komponen, ia tidak boleh menggunakan Kaedah pembolehubah tempatan; >parent.component.ts

Anda boleh mengakses sifat dan kaedah komponen anak melalui pembolehubah child1Component

5

@ViewChild(Child1Component) private child1Component!: Child1Component;
Salin selepas log masuk
Untuk mencapai komunikasi antara mana-mana komponen, kami boleh menggabungkan objek BehaviorSubject dalam Rxjs untuk mencipta perkhidmatan kongsi untuk kegunaan BehaviorSubject, sila rujuk blog ini

blog.tcs-y; .com/2019/10/08/…

Buat dataService.ts

Suntikan perkhidmatan dalam pembina komponen 1 dan tetapkan data child1.component.ts

child1.component.html
import {BehaviorSubject} from &#39;rxjs&#39;;
import { Injectable} from &#39;@angular/core&#39;;
@Injectable(
  {providedIn: &#39;root&#39;}
)
export class DataService {
  data: BehaviorSubject<number> = new BehaviorSubject<number>(0);
}
Salin selepas log masuk

Suntikan perkhidmatan dalam pembina komponen 2 dan langgan data

child2.component .ts
constructor(private dataService: DataService) {}
    // 设置data的值
changeData(): void {
    this.dataService.data.next(10);
}
Salin selepas log masuk

Lagi Untuk pengetahuan berkaitan pengaturcaraan, sila lawati:
<button (click)="changeData()">Click</button>
Salin selepas log masuk
Pengenalan kepada Pengaturcaraan

! !

Atas ialah kandungan terperinci Perbincangan ringkas mengenai 5 kaedah komunikasi antara komponen Sudut. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:juejin.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan