Nội dung chiếu trong Angular

Tram Ho

Trong bài viết này mình xin phép chia sẻ đôi chút về Content Projection trong Angular.

Content projection cho phép bạn có thế chèn một ảnh của DOM trong component của bạn. Nói đơn giản thì, bạn nếu bạn muốn chèn các phần tử HTML hoặc các component vào một component, để thực hiện việc này thì bạn cần sử dụng đến content projection. Trong Angular thì bạn có thể sử sụng < ng-content></ng-content>.
Chúng ta có một component GreetComponent sau

Bây giờ nếu chúng ta muốn sử dụng GreetComponent trong một component khác và in ra một thông điệp chòa mừng thì chúng ta sẽ sử dụng @Input . Theo các này thì một GreetComponent được sửa đổi giống như sau:

@Input có thể giúp chúng ta truyền vào một chuỗi đơn giản dễ dàng, nhưng với các loại dữ liệu khác thì sao?? Ví dụ:

  1. Inner HTML
  2. HTML Elements
  3. Styled HTML
  4. Another Component, etc.

Khi này chúng ta hãy nghĩ ngay đến <ng-content></ng-content> và ta có đoạn code sửa đổi như sau:

Bây giờ chúng ta hãy tham chiếu GreetComponentAppComponent nhé:

Content Projection trong Angular còn khác nhiều phần nữa nhưng trong bài viết này mình mới nói đến @Input<ng-content></ng-content> thôi. Hẹn các bạn tại bài viết tiếp theo.

Chia sẻ bài viết ngay

Nguồn bài viết : Viblo