---
lang: en
title: 'API docs: core.application.component'
keywords: LoopBack 4.0, LoopBack 4
sidebar: lb4_sidebar
editurl: https://github.com/strongloop/loopback-next/tree/master/packages/core
permalink: /doc/en/lb4/apidocs.core.application.component.html
---

<!-- Do not edit this file. It is automatically generated by API Documenter. -->

[Home](./index.md) &gt; [@loopback/core](./core.md) &gt; [Application](./core.application.md) &gt; [component](./core.application.component.md)

## Application.component() method

Add a component to this application and register extensions such as controllers, providers, and servers from the component.

<b>Signature:</b>

```typescript
component<T extends Component = Component>(componentCtor: Constructor<T>, name?: string): Binding<T>;
```

## Parameters

|  Parameter | Type | Description |
|  --- | --- | --- |
|  componentCtor | <code>Constructor&lt;T&gt;</code> | The component class to add. |
|  name | <code>string</code> | Optional component name, default to the class name |

<b>Returns:</b>

`Binding<T>`

## Example


```ts

export class ProductComponent {
  controllers = [ProductController];
  repositories = [ProductRepo, UserRepo];
  providers = {
    [AUTHENTICATION_STRATEGY]: AuthStrategy,
    [AUTHORIZATION_ROLE]: Role,
  };
};

app.component(ProductComponent);

```


