- vừa được xem lúc

3 cách để giao tiếp giữa các component với nhau trong Angular 2+

0 0 104

Người đăng: Uy Tran

Theo Viblo Asia

Trong một ứng dụng Angular, thành phần được hướng theo component.

Có nhiều cách để chia sẻ dữ liệu, giao tiếp giữa các component trong ứng dụng, bài viết này mình sẽ tập trung vào 3 cách đơn giản sau:

  1. View child
  2. Event Emitter
  3. Data service BehaviourSubject

Bắt đầu thôi!

View child thông qua @Input

Trong ba cách thì sử dụng @Input là cách đơn giản nhất về cách khai báo cũng như sử dụng.

Để để chia sẻ biến hoặc giá trị nào đó từ component cha với component con bên trong, chúng ta có thể sử dụng @Input:

Ở children component: Khởi tạo:

// children.component.ts
import { Component, OnInit, Input } from '@angular/core'; @Component({ selector: 'app-children', template: ' <p> Children component
</p> <span>Message from parent component: {{childMessage}}</span> ', styleUrls: ['./children.component.css']
})
export class ChildrenComponent implements OnInit { @Input() childMessage: string; constructor() { } ngOnInit() { }
}

Thông qua biến @Input childMessage, parent component có thể truyền attribute vào children component.

Ở parent component chỉ việc khai báo:

// parent.component.ts
parentMessage: string = "Message from parent";

Ở template.html:

	<app-children [childMessage]="parentMessage"></app-children>

Vậy là ParentComponent đã có thể truyền attribute tới ChildrenComponent thông qua @Input.

EventEmitter

Cách thứ 2 là thông qua biến @Output sử dụng EventEmitter:

Event emitter được thiết kế để báo cho component cha khi component con có sự thay đổi.

Thông qua biến @Output, EventEmitter sẽ bắn một value nào đó ra ngoài, và component cha sẽ bắt được value này.

  • Ở component con:
<button class="btn btn-primary" (click)="voted()">Click to vote</button>
 // ... @Output() voteSize = new EventEmitter(); counter: number = 0; // ... voted() { this.counter ++; this.voteSize.emit(this.counter); // Hàm vote sẽ tăng counter lên 1, đồng thời thông qua EventEmitter bắn value counter này ra component cha } // ...
  • Ở component cha:
import { Component, OnInit, ViewChild } from '@angular/core'; @Component({ selector: 'app-parent', template: ' <app-children (voteSize)="voteCount($event)"></app-children> <h1>Total vote from children: {{vote}}</h1>
', styleUrls: ['./parent.component.css']
}) export class ParentComponent implements OnInit { vote: number = 0; constructor() { } ngOnInit() { } voteCount(value) { this.vote = value; }
}

Data service BehaviourSubject

Data service sử dụng BehaviourSubject (rxjs).

Rxjs hỗ trợ observes (consuming interface) và observables (push interface) (có bài viết đọc khá dễ hiểu, các bạn có thể tham khảo thêm ở đây).

Ở ví dụ sau mình sử dụng cả 2 interface trên của BehaviourSubject, thông qua hàm asObservable()

ng generate service services/data

File data.service.ts:

import { Injectable } from '@angular/core'; import { BehaviorSubject } from 'rxjs'; @Injectable({ providedIn: 'root'
})
export class DataService { messageSource = new BehaviorSubject<string>("default message"); currentMessage = this.messageSource.asObservable(); // có thể subcribe theo dõi thay đổi value của biến này thay cho messageSource constructor() { } // method này để change source message  changeMessage(message) { this.messageSource.next(message); }
}

Bây giờ để chia sẻ data giữa các component, chúng ta cần import DataService:

import { DataService } from '../services/data.service';

Gọi hàm changeMessage để push data:

 createMessage(message) { this.data.changeMessage(message); }

Và subcribe vào currentMessage để get data:

this.data.currentMessage.subscribe(message => this.message = message);

Các bạn có thể clone source code demo các example này tại đây: https://github.com/at-uytran/share-data-example

Như vậy mình vừa trình bày về 3 cách để giao tiếp giữa các component với nhau trong angular.

Hy vọng bài viết có thể giúp ích cho những ai còn thắc mắc hay đang tìm hiểu về cách giao tiếp giữa các component trong angular.

Cảm ơn vì đã ghé đọc bài viết, nếu các bạn có thắc mắc hay góp ý gì hãy để lại comment nhé.

Bình luận

Bài viết tương tự

- vừa được xem lúc

Giới thiệu Typescript - Sự khác nhau giữa Typescript và Javascript

Typescript là gì. TypeScript là một ngôn ngữ giúp cung cấp quy mô lớn hơn so với JavaScript.

0 0 525

- vừa được xem lúc

Cài đặt WSL / WSL2 trên Windows 10 để code như trên Ubuntu

Sau vài ba năm mình chuyển qua code trên Ubuntu thì thật không thể phủ nhận rằng mình đã yêu em nó. Cá nhân mình sử dụng Ubuntu để code web thì thật là tuyệt vời.

0 0 396

- vừa được xem lúc

Đặt tên commit message sao cho "tình nghĩa anh em chắc chắn bền lâu"????

. Lời mở đầu. .

1 1 738

- vừa được xem lúc

Tìm hiểu về Resource Controller trong Laravel

Giới thiệu. Trong laravel, việc sử dụng các route post, get, group để gọi đến 1 action của Controller đã là quá quen đối với các bạn sử dụng framework này.

0 0 358

- vừa được xem lúc

Phân quyền đơn giản với package Laravel permission

Như các bạn đã biết, phân quyền trong một ứng dụng là một phần không thể thiếu trong việc phát triển phần mềm, dù đó là ứng dụng web hay là mobile. Vậy nên, hôm nay mình sẽ giới thiệu một package có thể giúp các bạn phân quyền nhanh và đơn giản trong một website được viết bằng PHP với framework là L

0 0 449

- vừa được xem lúc

Bạn đã biết các tips này khi làm việc với chuỗi trong JavaScript chưa ?

Hi xin chào các bạn, tiếp tục chuỗi chủ đề về cái thằng JavaScript này, hôm nay mình sẽ giới thiệu cho các bạn một số thủ thuật hay ho khi làm việc với chuỗi trong JavaScript có thể bạn đã hoặc chưa từng dùng. Cụ thể như nào thì hãy cùng mình tìm hiểu trong bài viết này nhé (go).

0 0 433