What is content projection in Angular and How to use it?

What is a content project in Angular?

Content projection allows you to insert a shadow DOM in your component. To put it simply, if you want to insert HTML elements or other components in a component, then you do that using the concept of content projection. In Angular, you achieve content projection using < ng-content >< /ng-content>{alertInfo}

Angular <ng-content> allows us to inject the content dynamically at runtime.
Let’s consider an example. Assume you want to create a button that can be used in multiple places in your project, and you need to change the button text based on the code placement.

Let’s create a button component

import { Component, OnInit } from '@angular/core';

@Component({
  selector: 'app-button',

  template: `
    <button>
      <ng-content></ng-content>
    </button>
  `
})
export class ButtonComponent implements OnInit {
  constructor() {}

  ngOnInit() {}
}

In the above code ng-content is placeholder for the button text. Component who is using will provide the text and it will replace by the angular framework

For example, I am using the button component in app.component as shown below

<h1>Code Guru</h1>
<app-button>
  Login
</app-button>
<app-button>
  Sign Up
</app-button>

If you run the application, you will see the following output.

DEMO

Next Post Previous Post
No Comment
Add Comment
comment url