Rumah hujung hadapan web tutorial js Bagaimanakah komponen sudut berkomunikasi? 2 kaedah untuk komunikasi komponen ibu bapa-anak

Bagaimanakah komponen sudut berkomunikasi? 2 kaedah untuk komunikasi komponen ibu bapa-anak

Aug 06, 2021 am 10:32 AM
angular Komunikasi komponen

Artikel ini akan membawa anda melalui komunikasi komponen dalam Angular dan memperkenalkan kaedah komunikasi antara komponen ibu bapa dan anak serta komunikasi antara komponen tanpa hubungan langsung.

Bagaimanakah komponen sudut berkomunikasi? 2 kaedah untuk komunikasi komponen ibu bapa-anak

Dalam aplikasi sebenar, komponen kami akan dikaitkan dalam struktur pokok, jadi hubungan antara komponen adalah terutamanya:

  • Hubungan bapa-anak

  • Hubungan abang

  • Tiada hubungan langsung

【 Tutorial berkaitan cadangan: "tutorial sudut"]

Sediakan persekitaran kita:

1. Cipta headerKomponen: ng g c components/header

<app-button></app-button>
<app-title></app-title>
<app-button></app-button>
Salin selepas log masuk
export class HeaderComponent implements OnInit {

  constructor() {}

  ngOnInit(): void {}
}
Salin selepas log masuk

2 Cipta komponen title: ng g c components/title

<span>{{title}}</span>
Salin selepas log masuk
export class TitleComponent implements OnInit {

  public title: string = &#39;标题&#39;;

  constructor() {}

  ngOnInit(): void {}
}
Salin selepas log masuk

3 >buttonng g c components/button

<button>{{ btnName }}</button>
Salin selepas log masuk
export class ButtonComponent implements OnInit {
  public btnName: string = &#39;按钮&#39;;

  constructor() {}

  ngOnInit(): void {}
}
Salin selepas log masuk

Panggil terus

untuk komponen hubungan ibu bapa-anak, sila ambil perhatian bahawa Panggilan terus membuat gandingan antara komponen ibu bapa dan anak lebih tinggi Untuk menggunakannya dengan jelas, anda benar-benar perlu memanggilnya secara langsung.

1 Pasang komponen pengepala kami ke dalam apl supaya hubungan komponen induk-anak terbentuk antara apl dan pengepala

2 komponen untuk komponen kami komponen dikembangkan, kita boleh Memanggil sifat dan fungsi dalam pengepala subkomponen dalam apl komponen induk

# 5. Langkah keempat ialah beroperasi dalam templat html komponen induk. Kadang-kadang kita juga perlu melakukan operasi dalam ts komponen induk Sub-komponen dikendalikan dalam kelas, dan kami akan menunjukkan seterusnya. <app-header #header></app-header>

6. Kita perlu menggunakan penghias baharu

export class HeaderComponent implements OnInit {
  public name: string = &#39;HeaderComponent&#39;;

  printName(): void {
    console.log(&#39;component name is&#39;, this.name);
  }
}
Salin selepas log masuk

<app-header #header></app-header>
<p>
  调用子组件属性: {{ header.name }}
  <button (click)="header.printName()">调用子组件函数</button>
</p>
Salin selepas log masuk
@Input dan @Output

@ViewChild(Component)

Terpakai kepada komponen hubungan ibu bapa-anak
export class AppComponent {
  title = &#39;angular-course&#39;;

  @ViewChild(HeaderComponent)
  private header!: HeaderComponent;

	// 声明周期钩子: 组件及子组件视图更新后调用,执行一次
  ngAfterViewInit(): void {
    // 调用子组件属性
    console.log(this.header.name);
    // 调用子组件函数
    this.header.printName();
  }
}
Salin selepas log masuk

1 Kami mentakrifkan dalam komponen untuk merungkai masalah pengembangan kompleks yang disebabkan oleh panggilan langsung dalam komponen <. 🎜>

2. Tambahkan penghias @Input() pada atribut

dalam komponen :

3. Tambahkan atribut tajuk pada komponen pengepala dan tetapkan nilai : header titletitle4 Mari kita gunakan komponen

dalam templat

komponen title seperti ini: title@Input() public title: string = &#39;标题&#39;;

5 kesan semasa. Walaupun antara muka Hodoh, tetapi adakah lebih mudah untuk menetapkan

pada masa akan datang apabila menggunakan komponen public title: string = &#39;我是新标题&#39;;

headerhtml 6. Langkah di atas menyedari bahawa data komponen induk dihantar kepada komponen anak, kemudian Mari kita lihat seterusnya bagaimana data komponen anak dihantar ke komponen induk Mari kita gunakan penghias title untuk melaksanakan perkara berikut <app-title [title]="title"></app-title>

7. Tambah? atribut

kepada kelas ts bagi komponen title :

Bagaimanakah komponen sudut berkomunikasi? 2 kaedah untuk komunikasi komponen ibu bapa-anak8 Edarkan data dengan kerap dalam kelas ts bagi komponen

@Output()

9. . Sekarang mari kita ubah suai komponen induk pengepala untuk menerima data yang dihantar:

titletitleChange@Output() public titleChange = new EventEmitter();

Gunakan minat mudah perkhidmatan untuk komunikasititle

ngOnInit(): void {
  // 定时将子组件的数据进行派发
  setInterval(() => {
  	this.titleChange.emit(this.title);
	}, 1500);
}
Salin selepas log masuk

Terpakai kepada komponen yang tidak mempunyai hubungan langsung
<app-title 
	[title]="title" 
  (titleChange)="onChildTitleChange($event)">
</app-title>
Salin selepas log masuk
onChildTitleChange(value: any) {
	console.log(&#39;onChildTitleChange: >>&#39;, value);
}
Salin selepas log masuk

1 Memandangkan kita ingin berkomunikasi melalui perkhidmatan, mari buat perkhidmatan dahulu: , dan kami mengisytiharkan atribut jenis

untuk membantu komunikasi

2 Untuk menyelamatkan masalah, kami tidak akan mencipta semula komponen, kerana komponen butang dan komponen tajuk dalam

kami adalah komponen yang. tidak mempunyai hubungan langsung.

Bagaimanakah komponen sudut berkomunikasi? 2 kaedah untuk komunikasi komponen ibu bapa-anak3. Ubah komponen

kami dan tambahkan acara klik untuk mencetuskan fungsi

ng g s services/EventBusSubject

4. Simulasikan pemerolehan data dalam komponen
@Injectable({
  providedIn: &#39;root&#39;,
})
export class EventBusService {
  public eventBus: Subject<any> = new Subject();

  constructor() {}
}
Salin selepas log masuk

header

buttonGunakan kuki, sesi atau storan setempat untuk berkomunikasi triggerEventBus

export class ButtonComponent implements OnInit {
  public btnName: string = &#39;按钮&#39;;

  constructor(public eventBusService: EventBusService) {}

  ngOnInit(): void {}

  public triggerEventBus(): void {
    this.eventBusService.eventBus.next(&#39;我是按钮组件&#39;);
  }
}
Salin selepas log masuk

title

1. Kami masih menggunakan komponen title dan komponen button untuk demonstrasi. Mari kita tunjukkan button, semua yang lain adalah sama. localstorage

2. Simpan

dalam cangkuk title komponen ngOnInit() ke title: localstoragewindow.localStorage.setItem('title', this.title);

3. Dapatkan data dalam komponen butang:

const title = window.localStorage.getItem('title');

Kesimpulan:

Dalam artikel ini kami memperkenalkan komunikasi komponen Angular, yang menyediakan asas untuk komunikasi yang munasabah antara Jaminan komponen kami , kami telah menggunakan komponen dengan memperkenalkan teg setakat ini.

Alamat asal: https://juejin.cn/post/6991471300837572638

Pengarang: Xiaoxin

Untuk lebih banyak pengetahuan berkaitan pengaturcaraan, sila Lawati :

Pengenalan kepada Pengaturcaraan! !

Atas ialah kandungan terperinci Bagaimanakah komponen sudut berkomunikasi? 2 kaedah untuk komunikasi komponen ibu bapa-anak. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

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

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Bagaimana untuk memasang Angular pada Ubuntu 24.04 Bagaimana untuk memasang Angular pada Ubuntu 24.04 Mar 23, 2024 pm 12:20 PM

Angular.js ialah platform JavaScript yang boleh diakses secara bebas untuk mencipta aplikasi dinamik. Ia membolehkan anda menyatakan pelbagai aspek aplikasi anda dengan cepat dan jelas dengan memanjangkan sintaks HTML sebagai bahasa templat. Angular.js menyediakan pelbagai alatan untuk membantu anda menulis, mengemas kini dan menguji kod anda. Selain itu, ia menyediakan banyak ciri seperti penghalaan dan pengurusan borang. Panduan ini akan membincangkan cara memasang Angular pada Ubuntu24. Mula-mula, anda perlu memasang Node.js. Node.js ialah persekitaran berjalan JavaScript berdasarkan enjin ChromeV8 yang membolehkan anda menjalankan kod JavaScript pada bahagian pelayan. Untuk berada di Ub

Penjelasan terperinci tentang pengurus keadaan pembelajaran sudut NgRx Penjelasan terperinci tentang pengurus keadaan pembelajaran sudut NgRx May 25, 2022 am 11:01 AM

Artikel ini akan memberi anda pemahaman yang mendalam tentang pengurus negeri Angular NgRx dan memperkenalkan cara menggunakan NgRx saya harap ia akan membantu anda!

Artikel yang meneroka pemaparan sisi pelayan (SSR) dalam Angular Artikel yang meneroka pemaparan sisi pelayan (SSR) dalam Angular Dec 27, 2022 pm 07:24 PM

Adakah anda tahu Angular Universal? Ia boleh membantu tapak web menyediakan sokongan SEO yang lebih baik!

Cara menggunakan PHP dan Angular untuk pembangunan bahagian hadapan Cara menggunakan PHP dan Angular untuk pembangunan bahagian hadapan May 11, 2023 pm 04:04 PM

Dengan perkembangan pesat Internet, teknologi pembangunan bahagian hadapan juga sentiasa bertambah baik dan berulang. PHP dan Angular ialah dua teknologi yang digunakan secara meluas dalam pembangunan bahagian hadapan. PHP ialah bahasa skrip sebelah pelayan yang boleh mengendalikan tugas seperti memproses borang, menjana halaman dinamik dan mengurus kebenaran akses. Angular ialah rangka kerja JavaScript yang boleh digunakan untuk membangunkan aplikasi satu halaman dan membina aplikasi web berkomponen. Artikel ini akan memperkenalkan cara menggunakan PHP dan Angular untuk pembangunan bahagian hadapan, dan cara menggabungkannya

Analisis ringkas tentang cara menggunakan editor monaco dalam sudut Analisis ringkas tentang cara menggunakan editor monaco dalam sudut Oct 17, 2022 pm 08:04 PM

Bagaimana untuk menggunakan monaco-editor dalam sudut? Artikel berikut merekodkan penggunaan monaco-editor dalam sudut yang digunakan dalam perniagaan baru-baru ini. Saya harap ia akan membantu semua orang!

Analisis ringkas komponen bebas dalam Angular dan lihat cara menggunakannya Analisis ringkas komponen bebas dalam Angular dan lihat cara menggunakannya Jun 23, 2022 pm 03:49 PM

Artikel ini akan membawa anda melalui komponen bebas dalam Angular, cara mencipta komponen bebas dalam Angular, dan cara mengimport modul sedia ada ke dalam komponen bebas saya harap ia akan membantu anda!

Komponen sudut dan sifat paparannya: memahami lalai bukan blok Komponen sudut dan sifat paparannya: memahami lalai bukan blok Mar 15, 2024 pm 04:51 PM

Tingkah laku paparan lalai untuk komponen dalam rangka kerja Angular bukan untuk elemen peringkat blok. Pilihan reka bentuk ini menggalakkan pengkapsulan gaya komponen dan menggalakkan pembangun untuk secara sedar menentukan cara setiap komponen dipaparkan. Dengan menetapkan paparan sifat CSS secara eksplisit, paparan komponen Sudut boleh dikawal sepenuhnya untuk mencapai reka letak dan responsif yang diingini.

Apakah yang perlu saya lakukan jika projek itu terlalu besar? Bagaimana untuk membahagikan projek Angular dengan munasabah? Apakah yang perlu saya lakukan jika projek itu terlalu besar? Bagaimana untuk membahagikan projek Angular dengan munasabah? Jul 26, 2022 pm 07:18 PM

Projek Angular terlalu besar, bagaimana untuk membahagikannya secara munasabah? Artikel berikut akan memperkenalkan kepada anda cara membahagikan projek Angular secara munasabah. Saya harap ia akan membantu anda!

See all articles