Skip to main content

Dependency Injection in Angular

🚀 What is Dependency Injection?

  • Dependency Injection (DI) is a design pattern.
  • It allows a class to receive its dependencies (services, objects) from the outside, rather than creating them itself.
  • Angular has a powerful built-in DI system that manages and injects dependencies automatically.

📦 Why Use Dependency Injection?

Benefit Description
Loose Coupling Classes are not tightly tied to their dependencies.
Reusability Easier to reuse code and services.
Testability Easier to mock dependencies for unit testing.
Maintainability Cleaner, more modular code.

🔥 Basic Example

Suppose you have a service that provides user data:

1. Create a Service

ng generate service user

This generates user.service.ts:

import { Injectable } from '@angular/core';

@Injectable({
  providedIn: 'root' // Angular will automatically inject it
})
export class UserService {
  getUser() {
    return { name: 'John Doe', age: 30 };
  }
}

@Injectable({ providedIn: 'root' }) makes the service available application-wide.


2. Inject Service into a Component

In your app.component.ts:

import { Component } from '@angular/core';
import { UserService } from './user.service';

@Component({
  selector: 'app-root',
  template: `
    <h1>{{ user.name }}</h1>
    <p>Age: {{ user.age }}</p>
  `
})
export class AppComponent {
  user: any;

  constructor(private userService: UserService) {
    this.user = this.userService.getUser();
  }
}

✅ Angular automatically injects an instance of UserService into the AppComponent.


📄 How Dependency Injection Works Internally

  1. Service Registration
    Services are registered in Angular's Injector (thanks to @Injectable).
  2. Service Resolution
    Angular checks the constructor parameters of a component/class.
  3. Service Provision
    Angular creates or reuses an instance and injects it.

🛠️ Providing Services in Different Scopes

Scope How to Provide Effect
Application-wide @Injectable({ providedIn: 'root' }) Same instance everywhere
Module-level In providers array of a module Unique instance per module
Component-level In providers array of a component Unique instance per component

📚 Advanced: Manual Injection with Injector

You can manually inject dependencies using Angular's Injector if needed:

import { Injector } from '@angular/core';

constructor(private injector: Injector) {}

someMethod() {
  const userService = this.injector.get(UserService);
  console.log(userService.getUser());
}

⚡ But 99% of the time, constructor injection (shown earlier) is enough!


📜 Summary

  • DI simplifies creating and managing service instances.
  • Services hold reusable logic or data.
  • Angular's injector finds and injects the required services automatically.

Comments

Popular posts from this blog

Car Wash System vb.net

This software consists of a database that save the registration number of every vehicle being wash along side with the date, type of wash made and price Screen Shot Source Code To view records in the database: Dim conn As OleDbConnection = New OleDbConnection("Provider=Microsoft.ACE.OLEDB.12.0;Data Source=|DataDirectory|\washRcd.accdb;Persist Security Info=False") Dim sql As String sql = " SELECT * FROM tblwash" conn.Open() Dim dt As New DataTable Dim cmd2 As New OleDb.OleDbDataAdapter(sql, conn) cmd2.Fill(dt) DataGridView1.DataSource = dt DataGridView1.Refresh() conn.Close() To insert new record in the database: Private Sub insert() Dim conn As OleDbConnection = New OleDbConnection("Provider=Microsoft.ACE.OLEDB.12.0;Data Source=|DataDirectory|\washRcd.accdb;Persist Security Info=False") Dim updateSql As String = String.Format(...

C# Windows Form : PetCare

A desktop application using C# as technology. the application is titled as "PETCARE" a system that a pet shop or veterinary can use it to store basic information about the pet's owner, details about the pet and the purpose of the visit to the veterinary or pet shot. The system also contained a stock management module that is used to track pet food purchased by a particular customer Screen Shot You can login both as a staff or as the admin. the admin has the privilege to register new staff and view details about transaction and other sensitive information. The system encrypt user password using MD5 algorithm The home screen of the application You can either add a new pet with its owner details or add another pet belonging to the same owner. both can be done using the same form below. and each pet owner will be given a reference number. Veterinary can use the application to store information about treatment done for a particular pet Can t...

Face recognition using EmguCV 3.0 and typing pattern recognition

Introduction An MSc project with the title Student Examination System, where the objective is to put the students in an examination condition but instead of having an invigilator in an examination center, the system will cater for the proper ongoing of the exam. the system can be used as an online examination system The system is able to: Recognizing the face shape of a particular student Detect if there is more than one person in the examination room  Analyze the typing pattern of a student and detect if any one person is taking part in the exam voice recognition for the student and detect if there is more than one person speaking in the examination room Setup Download Emgu CV from  http://www.emgu.com/wiki/index.php/Main_Page Download Haarcascade from  https://github.com/opencv/opencv/tree/master/data/haarcascades Create an account at  https://www.keytrac.net/ Face recognition The snippet below illustrates how the Emgu CV is loaded whe...