当前位置: 首页 > news >正文

angular入门基础教程(九)依赖注入(DI)

依赖注入

Angular 中的依赖注入(DI)是框架最强大的特性之一。可以将依赖注入视为 Angular 在运行时为你的应用 提供所需资源的能力。依赖项可以是服务或其他资源。

使用服务的一种方式是作为与数据和 API 交互的方式。为了使服务可重用,应该将逻辑保留在服务中,并在需要时在整个应用程序中共享它。

创建服务

创建服务,需要使用 Angular CLI 命令 ng generate service。

  • 文件里面必须引入 Injectable,配置装饰器
import { Injectable } from "@angular/core";@Injectable({providedIn: "root",
})
export class CarServiceService {cars = ["Sunflower GT", "Flexus Sport", "Sprout Mach One"];getCars() {return this.cars;}getCar(id: number) {return this.cars[id];}
}
  • 需要使用这个服务的组件中
import { Component, inject } from "@angular/core";
import { CarServiceService } from "../../services/car-service.service";
@Component({selector: "app-about", //这个名字是我们在被的组件中使用的时候,需要写这个名字作为组件名standalone: true,imports: [FormsModule],templateUrl: "./about.component.html",styleUrl: "./about.component.css",
})
export class AboutComponent {carServices = inject(CarServiceService);display = "";constructor() {this.display = this.carServices.getCars().join(" ❤ ");}
}

在这里插入图片描述
这样我们就实现了ng中的依赖注入

作为构造函数注入

这里有点类似于java中的@Autowired,思想差不多,感觉

export class AboutComponent {// carServices = inject(CarServiceService);username = "";display = "";constructor(private carServices: CarServiceService) {this.display = this.carServices.getCars().join(" ❤❤ ");}
}

在这里插入图片描述

http://www.lryc.cn/news/410425.html

相关文章:

  • 小学生也能听得懂的大模型 - Transformer 1
  • 听说它可以让代码更优雅
  • 自写ApiTools工具,功能参考Postman和ApiPost
  • 《深入浅出WPF》学习笔记一.解析WPF程序
  • Scrapy框架中,如何有效地管理和维护爬虫的日志记录?
  • Laravel Sanctum:简化无状态API认证的新纪元
  • OCC BRepOffsetAPI_ThruSections使用
  • driver. findElement()vs Selenium中的Webelement. findElement()
  • jquery图片懒加载
  • 【端口】-
  • 【研发日记】Matlab/Simulink技能解锁(十一)——Stateflow中的en、du、ex应用对比
  • 《学会 SpringMVC 系列 · 剖析篇(上)》
  • 【Vulnhub系列】Vulnhub_SecureCode1靶场渗透(原创)
  • 【C语言】结构体详解 -《探索C语言的 “小宇宙” 》
  • 基于DTW距离的KNN算法实现股票高相似筛选案例
  • GD32 - IIC程序编写
  • 将项目部署到docker容器上
  • 免费【2024】springboot宠物美容机构CRM系统设计与实现
  • 搞懂数据结构与Java实现
  • Stable Diffusion 图生图
  • 语言转文字
  • ref函数
  • 7/30 bom和dom
  • 【Golang 面试 - 进阶题】每日 3 题(五)
  • MySQL,GROUP BY子句的作用是什么?having和where的区别在哪里说一下jdbc的流程
  • 1._专题1_双指针_C++
  • Spring集成ES
  • 力扣高频SQL 50题(基础版)第二十六题
  • WIFI 接收机和发射机同步问题+CFO/SFO频率偏移问题
  • ubuntu安装并配置flameshot截图软件