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

Sử dụng @Input() và @Output() trong angular

0 0 26

Người đăng: Gấu con

Theo Viblo Asia

Trong angular, chúng ta sử dụng khai báo @Input() và @Output() để chia sẻ dữ liệu giữa một thành phần cha và một hoặc nhiều thành phần con với nhau.
Khai báo @Input() cho phép thành phần cha cập nhật hoặc truyền dữ liệu sang thành phần con. Ngược lại, @Output() cho phép thành phần con gửi dữ liệu đến một thành phần cha.

Sending data to a child component

Khi sử dụng @input() chúng ta có thể truyền dữ liệu từ thành phần cha sang thành phần con một cách dễ dàng, ví dụ như ảnh minh họa:

Configuring the child component
Để sử dung @input() trong lớp thành phần con , trước tiên chúng ta phải import input và khai báo @input() trong lớp thành phần con như bên dưới:
src/app/item-detail/item-detail.component.ts

import { Component, Input } from '@angular/core'; @Component({ selector: 'app-item-detail', templateUrl: './item-detail.component.html', styleUrls: ['./item-detail.component.css']
}) export class ItemDetailComponent { @Input() item = ''; // decorate the property with @Input() }

Đoạn code trên khai báo @Input() với thuộc tính item, cái thuộc tính có kiểu dữ liệu là string hoặc có thể là bất kỳ kiểu dữ liệu khác như: number, string, boolean, object.
Giá trị của thuộc tính item được truyền đến từ component cha nhé.
src/app/item-detail/item-detail.component.html

<p> Today's item: {{item}}
</p>

Configuring the parent component
Bây giờ chúng ta muốn truyền dữ liệu từ lớp thành phần cha sang lớp thành phần con, bạn hãy thêm selector <app-item-detail> của lớp thành phần con vào file app.component.html như dưới.
Sử dụng ràng buộc thuộc tính để ràng buộc thuộc tính item trong lớp thành phần con với thuộc tính currentItem của lớp thành phần cha.
src/app/app.component.html

<app-item-detail [item]="currentItem"></app-item-detail>

Trong lớp thành phần cha, chúng ta gán một giá trị cho thuộc tính currentItem.
src/app/app.component.ts

export class AppComponent { currentItem = 'Television';
}

Output:

Today's item: Television

Với @Input (), Angular truyền giá trị cho thuộc tính currentItem đến lớp thành phần con là item để hiển thị ra chuỗi Television.
Sơ đồ liên kết dữ liệu giữa lớp thành phần cha và con:

Sending data to a parent component

Khi dử dụng @Output(), bạn có thể truyền dữ liệu từ lớp thành phần con đến lớp thành phần cha:

Các bạn hãy xem ví dụ bên dưới để hiểu hơn về cách sử dụng @output() nhé :
Configuring the child component

  1. Import OutputEventEmitter vào lớp thành phần con:
import { Output, EventEmitter } from '@angular/core';
  1. Trong lớp con, khai báo @Output(). Ví dụ sau newItemEvent @Output () có một loại là EventEmitter, có nghĩa là nó là một sự kiện.
    src/app/item-output/item-output.component.ts
@Output() newItemEvent = new EventEmitter<string>();

Các phần khác nhau của khai báo được miêu tả như sau:

DECLARATION PARTS DETAILS
@Output() Một hàm decorator đánh dấu thuộc tính như một cách để dữ liệu đi từ con đến cha.
newItemEvent Tên của @Output ().
EventEmitter<string> Kiểu của @Output ().
new EventEmitter<string>() Yêu cầu Angular tạo một trình phát sự kiện mới và dữ liệu mà nó phát ra thuộc loại chuỗi.

3. Tạo một phương thức **addNewItem()** trong lớp thành phần con:

src/app/item-output/item-output.component.ts

import { Component, OnInit, Output, EventEmitter } from '@angular/core'; @Component({ selector: 'app-item-output', templateUrl: './item-output.component.html', styleUrls: ['./item-output.component.css']
})
export class ItemOutputComponent implements OnInit { constructor() { } ngOnInit(): void { } @Output() newItemEvent = new EventEmitter<string>(); addNewItem(value: string) { this.newItemEvent.emit(value); }
} 

src/app/item-output/item-output.component.html

<label for="item-input">Add an item:</label>
<input type="text" id="item-input" #newItem>
<button type="button" (click)="addNewItem(newItem.value)">Add to parent's list</button>

Configuring the parent component
AppComponent trong ví dụ này có danh sách các items trong một mảng và một phương thức để thêm các mục khác vào mảng.

import { Component } from '@angular/core'; @Component({ selector: 'app-root', templateUrl: './app.component.html', styleUrls: ['./app.component.css']
}) export class AppComponent { items = ['item1', 'item2', 'item3', 'item4']; addItem(newItem: string) { this.items.push(newItem); }
}

Phương thức addItem () nhận một đối số dưới dạng một chuỗi và sau đó thêm chuỗi đó vào mảng items.

Configuring the parent's template

  1. Đầu tiên, trong template của thành phần cha, hãy liên kết phương thức của thành phần cha với sự kiện của thành phần con.
  2. Thêm selector của thành phần con là <app-item-output> vào bên trong template của thành phần cha.

src/app/app.component.html

<div class="container"> <app-item-output (newItemEvent)="addItem($event)"></app-item-output> <ul> <li *ngFor="let item of items">{{item}}</li> </ul>
</div>

Sự kiện (newItemEvent)="addItem($event)" kết nối đến sự kiện trong thành phần con newItemEvent, đến phương thức trong thành phần cha là addItem()

Output:

Using @Input() and @Output() together

Sử dụng @Input () và @Output () trên cùng một thành phần con như sau:
src/app/app.component.html

<app-input-output [item]="currentItem" (deleteRequest)="crossOffItem($event)">
</app-input-output>

Sơ đồ sau cho thấy các phần khác nhau của @Input () và @Output () trên thành phần con <app-input-output>.

Selector <app-input-output> với itemdeleteRequest là thuộc tính @Input () và @Output () trong lớp thành phần con.
Thuộc tính currentItem và phương thức crossOffItem () đều thuộc lớp thành phần cha.

Bình luận

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

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

Route in Angular JS

Router là một module được đặt tại @angular/router, cung cấp cho ứng dụng Angluar của chúng ta khả năng điều hướng và hiển thị nội dung phù hợp với địa chỉ URL. Với các ứng dụng web thông thường, việc điều hướng theo URL thường sẽ do phía server đảm nhiệm, giống như hình ảnh dưới đây là ví dụ với Rai

0 0 96

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

Có gì mới trong Angular 11

Phiên bản Angular 11.0.0 được phát hành vào tháng 11 năm 2020. Bản phát hành chính Angular 11 cung cấp các bản cập nhật trên toàn bộ nền tảng, bao gồm CLI và các components.

0 0 102

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

Pipe trong Angular

Xin chào tất cả mọi người, bài viết này minh xin giới thiệu về Pipe trong Angular, rất mong được mọi người theo dõi. 1) Pipe trong Angular là gì. . .

0 0 127

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

Angular Reactive Forms: Cách sử dụng FormArray

Trong bài viết này chúng ta sẽ tìm hiểu khi nào và cách sử dụng FormArray, cả trong Component và trong Template, ngoài ra chúng ta sẽ xem cách để custom validation cho nó. Vì sao chúng ta cần sử dụng FormArray.

0 0 107

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

RxJS và Reactive Programming

1 - Stream. Streams are a sequence of values over time.

0 0 356

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

Mapping class Java với Angular Typescript model – Chưa bao giờ dễ đến thế

Xin chào mọi người hôm nay mình giới thiệu một loại đồ chơi cực xịn cực hay ho luôn, đây là một thư viện giúp cho mọi người tạo ra 1 class Typescript trong dự án Frontend ở đây mình lấy ví dụ là Angul

0 0 95