GitPedia

Typedi

Simple yet powerful dependency injection tool for JavaScript and TypeScript.

From typestack·Updated June 19, 2026·View on GitHub·

TypeDI is a [dependency injection](https://en.wikipedia.org/wiki/Dependency_injection) tool for TypeScript and JavaScript. With it you can build well-structured and easily testable applications in Node or in the browser. The project is written primarily in TypeScript, distributed under the MIT License license, first published in 2015. It has gained significant community traction with 4,242 stars and 165 forks on GitHub. Key topics include: dependency-injection, inversion-of-control, ioc, typedi, typescript.

Latest release: v0.10.0
January 15, 2021View Changelog →

TypeDI

Build Status
codecov
npm version
Dependency Status

TypeDI is a dependency injection tool for TypeScript and JavaScript. With it you can build well-structured and easily testable applications in Node or in the browser.

Main features includes:

  • property based injection
  • constructor based injection
  • singleton and transient services
  • support for multiple DI containers

Installation

Note: This installation guide is for usage with TypeScript, if you wish to use
TypeDI without Typescript please read the documentation about how get started.

To start using TypeDI install the required packages via NPM:

bash
npm install typedi reflect-metadata

Import the reflect-metadata package at the first line of your application:

ts
import 'reflect-metadata'; // Your other imports and initialization code // comes here after you imported the reflect-metadata package!

As a last step, you need to enable emitting decorator metadata in your Typescript config. Add these two lines to your tsconfig.json file under the compilerOptions key:

json
"emitDecoratorMetadata": true, "experimentalDecorators": true,

Now you are ready to use TypeDI with Typescript!

Basic Usage

ts
import { Container, Service } from 'typedi'; @Service() class ExampleInjectedService { printMessage() { console.log('I am alive!'); } } @Service() class ExampleService { constructor( // because we annotated ExampleInjectedService with the @Service() // decorator TypeDI will automatically inject an instance of // ExampleInjectedService here when the ExampleService class is requested // from TypeDI. public injectedService: ExampleInjectedService ) {} } const serviceInstance = Container.get(ExampleService); // we request an instance of ExampleService from TypeDI serviceInstance.injectedService.printMessage(); // logs "I am alive!" to the console

Documentation

The detailed usage guide and API documentation for the project can be found:

Contributing

Please read our contributing guidelines to get started.

Contributors

Showing top 12 contributors by commit count.

View all contributors on GitHub →

This article is auto-generated from typestack/typedi via the GitHub API.Last fetched: 6/20/2026