带你了解Angular中的组件通讯和依赖注入

angular组件间怎么进行通讯?依赖注入是什么?下面本篇文章带大家简单了解一下组件通讯的方法,并介绍一下依赖注入,希望对大家有所帮助!

带你了解Angular中的组件通讯和依赖注入

1.  组件通讯

1.1  向组件内部传递数据


// favorite.component.tsimport { Input } from '@angular/core';export class FavoriteComponent {    @Input() isFavorite: boolean = false;}

注意:在属性的外面加 [] 表示绑定动态值,在组件内接收后是布尔类型,不加 [] 表示绑定普通值,在组件内接收后是字符串类型。【相关教程推荐:《angular教程》】

1.2  组件向外部传递数据

需求:在子组件中通过点击按钮将数据传递给父组件

// 子组件类import { EventEmitter, Output } from "@angular/core"export class FavoriteComponent {  @Output() change = new EventEmitter()  onClick() {    this.change.emit({ name: "张三" })  }}
// 父组件类export class AppComponent {  onChange(event: { name: string }) {    console.log(event)  }}

2.   依赖注入

2.1  概述

依赖注入 ( Dependency Injection ) 简称DI,是面向对象编程中的一种设计原则,用来减少代码之间的耦合度

class MailService {  constructor(APIKEY) {}}class EmailSender {  mailService: MailService  constructor() {    this.mailService = new MailService("APIKEY1234567890")  }  sendMail(mail) {    this.mailService.sendMail(mail)  }}const emailSender = new EmailSender()emailSender.sendMail(mail)

EmailSender 类运行时要使用 MailService 类,EmailSender 类依赖 MailService 类,MailService 类是 EmailSender 类的依赖项。

以上写法的耦合度太高,代码并不健壮。如果 MailService 类改变了参数的传递方式,在 EmailSender 类中的写法也要跟着改变

class EmailSender {  mailService: MailService  constructor(mailService: MailService) {    this.mailService = mailService;  }}const mailService = new MailService("APIKEY1234567890")const emailSender = new EmailSender(mailService)

在实例化 EmailSender 类时将它的依赖项通过 constructor 构造函数参数的形式注入到类的内部,这种写法就是依赖注入。

通过依赖注入降了代码之间的耦合度,增加了代码的可维护性。MailService 类中代码的更改再也不会影响 EmailSender

2.2  DI 框架

Angular 有自己的 DI 框架,它将实现依赖注入的过程隐藏了,对于开发者来说只需使用很简单的代码就可以使用复杂的依赖注入功能。

AngularDI 框架中有四个核心概念:

Dependency:组件要依赖的实例对象,服务实例对象

Token:获取服务实例对象的标识

Injector:注入器,负责创建维护服务类的实例对象并向组件中注入服务实例对象。

知了追踪 知了追踪

AI智能信息助手,智能追踪你的兴趣资讯

知了追踪 64 查看详情 知了追踪

Provider:配置注入器的对象,指定创建服务实例对象的服务类和获取实例对象的标识。

2.2.1  注入器 Injectors

注入器负责创建服务类实例对象,并将服务类实例对象注入到需要的组件中

创建注入器

import { ReflectiveInjector } from "@angular/core"// 服务类class MailService {}// 创建注入器并传入服务类const injector = ReflectiveInjector.resolveAndCreate([MailService])

获取注入器中的服务类实例对象

const mailService = injector.get(MailService)

服务实例对象为单例模式,注入器在创建服务实例后会对其进行缓存

const mailService1 = injector.get(MailService)const mailService2 = injector.get(MailService)console.log(mailService1 === mailService2) // true

不同的注入器返回不同的服务实例对象

const injector = ReflectiveInjector.resolveAndCreate([MailService])const childInjector = injector.resolveAndCreateChild([MailService])const mailService1 = injector.get(MailService)const mailService2 = childInjector.get(MailService)console.log(mailService1 === mailService2) // false

服务实例的查找类似函数作用域链,当前级别可以找到就使用当前级别,当前级别找不到去父级中查找

const injector = ReflectiveInjector.resolveAndCreate([MailService])const childInjector = injector.resolveAndCreateChild([])const mailService1 = injector.get(MailService)const mailService2 = childInjector.get(MailService)console.log(mailService1 === mailService2) // true

2.2.2  提供者 Provider

配置注入器的对象,指定了创建实例对象的服务类和访问服务实例对象的标识

const injector = ReflectiveInjector.resolveAndCreate([  { provide: MailService, useClass: MailService }])

访问依赖对象的标识也可以是字符串类型

const injector = ReflectiveInjector.resolveAndCreate([  { provide: "mail", useClass: MailService }])const mailService = injector.get("mail")

useValue

const injector = ReflectiveInjector.resolveAndCreate([  {    provide: "Config",    useValue: Object.freeze({      APIKEY: "API1234567890",      APISCRET: "500-400-300"    })  }])const Config = injector.get("Config")

将实例对象和外部的引用建立了松耦合关系,外部通过标识获取实例对象,只要标识保持不变,内部代码怎么变都不会影响到外部

更多编程相关知识,请访问:编程视频!!

以上就是带你了解Angular中的组件通讯和依赖注入的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/560944.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月10日 00:58:38
下一篇 2025年11月10日 00:59:26

相关推荐

  • JavaScript依赖注入与控制反转

    控制反转(IoC)将依赖创建交给外部容器,依赖注入(DI)是实现IoC的具体方式,通过构造函数、方法或属性注入依赖,实现组件解耦、易于测试与配置灵活,JavaScript可通过函数式编程或自定义容器实现DI/IoC。 依赖注入(Dependency Injection, DI)和控制反转(Inver…

    2025年12月21日
    000
  • JavaScript依赖注入模式

    依赖注入通过外部注入依赖降低耦合,提升可测试性;JavaScript中可用构造函数、方法参数或容器实现,适用于服务解耦、配置管理等场景。 依赖注入(Dependency Injection,简称DI)是一种设计模式,用于实现控制反转(IoC),它能有效降低代码间的耦合度,提升可测试性和可维护性。在J…

    2025年12月20日
    100
  • 什么是 JavaScript 的装饰器在自动依赖注入框架中的应用?

    装饰器是用于类或属性的元数据标记,帮助DI框架识别依赖关系。通过@Injectable()等装饰器标注可注入类,结合emitDecoratorMetadata反射机制,容器自动解析构造函数参数并递归实例化依赖,实现自动装配。NestJS等框架利用此特性完成模块化与解耦,需开启experimental…

    2025年12月20日
    000
  • c++如何实现一个简单的依赖注入(DI)容器_c++控制反转(IoC)设计【架构】

    C++轻量级DI容器通过控制反转将对象创建与依赖管理交由外部容器处理,基于C++17+实现,强调接口与实现分离、依赖抽象而非具体。 在 C++ 中实现一个轻量级依赖注入(DI)容器,核心是把对象的创建和依赖关系的管理从类内部抽离出来,交由外部容器统一控制——这就是控制反转(IoC)的本质。它不依赖框…

    2025年12月19日
    000
  • C++如何进行依赖注入_使用DI框架或手动实现降低C++类之间的耦合

    依赖注入通过外部传递依赖降低耦合,提升可测试性与维护性;2. C++中常用构造函数注入,如将Logger通过unique_ptr传入UserManager;3. 复杂场景可用Boost.DI等轻量库实现编译时依赖解析,无运行时开销。 在C++中进行依赖注入(Dependency Injection,…

    2025年12月19日
    000
  • C++如何实现一个简单的依赖注入容器_C++面向接口编程与控制反转(IoC)

    控制反转通过外部容器管理对象依赖,依赖注入则将依赖通过构造函数等方式传入。使用C++模板和工厂模式可实现简易DI容器,以std::type_index为键注册类型与创建函数,支持接口到实现的绑定及单例生命周期管理,提升代码解耦与可测试性。 在C++中实现一个简单的依赖注入(Dependency In…

    2025年12月19日
    000
  • c++怎么实现一个简单的依赖注入容器_C++软件设计模式与依赖注入实现

    依赖注入通过外部注入依赖实现解耦,C++可用模板与工厂模式实现DI容器。定义DIContainer类,利用std::unordered_map存储类型名到工厂函数的映射,通过register_type注册构造逻辑,resolve解析实例。示例中ILogger与IService通过lambda工厂注册…

    2025年12月19日
    000
  • c++怎么实现一个简单的依赖注入容器_C++中实现DI容器的设计与原理解析

    答案:C++依赖注入容器通过模板和可变参数实现类型注册与依赖解析。支持构造函数注入和单例管理,利用type_index映射接口与实现,结合lambda创建实例,实现控制反转。 依赖注入(Dependency Injection, DI)是一种设计模式,用于解耦组件之间的依赖关系。在C++中,虽然没有…

    2025年12月19日
    000
  • C++依赖注入模式 松耦合组件设计

    依赖注入通过外部传入依赖实现松耦合,提升可测试性与可维护性。1. 核心是控制反转,依赖通过构造函数、setter或接口注入。2. 使用抽象接口(如ILogger)解耦具体实现。3. DataService通过构造函数接收ILogger,无需关心具体日志实现。4. 好处包括易于测试、运行时替换、代码复…

    2025年12月18日
    000
  • C++中依赖注入怎么实现 松耦合设计技巧

    答案:C++中通过构造函数注入、接口抽象和智能指针实现依赖注入,提升可测试性与松耦合;推荐使用工厂模式管理对象创建,结合前向声明减少编译依赖,确保依赖抽象而非具体实现。 在C++中实现依赖注入(Dependency Injection, DI)并构建松耦合系统,核心是将对象的依赖关系从内部创建转移到…

    2025年12月18日
    000
  • 怎样实现C++的依赖注入 构造函数注入与接口注入实践

    构造函数注入和接口注入是依赖注入的两种常见方式。构造函数注入通过构造函数传递依赖,优点是简单直接、依赖关系明确,但可能导致构造函数参数过多;接口注入则通过接口方法设置依赖,灵活性高,可在运行时动态改变依赖,但实现较繁琐。选择时需根据依赖是否稳定及是否需要动态变化决定:若依赖在对象创建时确定且稳定,应…

    2025年12月18日 好文分享
    000
  • 依赖注入框架选型:Boost.DI vs Fruit终极评测

    boost.di适合复杂项目,fruit适合轻量需求。1. boost.di灵活、支持多种注入方式和生命周期策略,但学习曲线陡峭、编译时间长;2. fruit简单易用、编译快、性能好,但仅支持构造函数注入且生命周期管理有限;3. 项目规模大、复杂度高选boost.di,规模小、性能要求高选fruit…

    2025年12月18日 好文分享
    000
  • C++ 框架如何利用依赖注入来增强可维护性?

    在 c++++ 中,依赖注入 (di) 是一种设计模式,通过外部注入器而不是在组件内部硬编码来管理组件依赖项,提高复杂应用程序的可维护性。它包括以下步骤:定义 di 容器来创建和管理依赖项。使用依赖注入框架将依赖项注入到组件中。组件接收注入的依赖项作为参数,而不是直接创建或管理它们。di 的优势包括…

    2025年12月18日
    000
  • C++框架如何采用依赖注入实现灵活性与可维护性?

    di 增强了 c++++ 框架的灵活性与可维护性,其优势包括:松散耦合:组件与依赖关系之间的联系减弱,提高了可测试性和重用性。可维护性:无需修改客户端代码即可更改依赖关系,简化维护。灵活性:通过注入不同的依赖关系,可以轻松创建框架行为的不同变体。手动 di 实现方法提供了直接控制 di 过程的轻量级…

    2025年12月18日
    000
  • 了解C++框架中的依赖注入机制

    在 c++++ 中使用依赖注入框架(如 boost.di)可以简化对象与依赖项之间的交互,从而实现以下优点:松散耦合:对象在编译时与依赖无关,便于修改和重用。可测性:方便通过模拟依赖项测试对象。可扩展性:可轻松添加或移除依赖,无需修改对象。 C++ 框架中的依赖注入 依赖注入是软件开发中的一种技术,…

    2025年12月18日
    000
  • C++ 框架中依赖注入优化性能的最佳实践

    最佳實踐對 c++++ 框架中依賴注入的性能優化:使用輕量級容器和按需解析依賴項以降低開銷。使用臨時作用域、單例和智能指針優化依賴項作用域。批量解析請求和使用依賴項生成器以提升解析效率。使用 di 配置文件和插件架構實現靈活的配置和擴展。 C++ 框架中依赖注入优化性能的最佳实践 简介 依赖注入 (…

    2025年12月18日
    000
  • C++ 框架的依赖注入最佳实践

    c++++ 框架依赖注入最佳实践使用接口而不是具体类型:确保容器能够创建依赖项的实例。使用构造函数注入:简单且灵活地注入依赖项。使用绑定对象:在无法使用构造函数注入时,绑定依赖项。使用依赖项规范:确保注入依赖项的类型正确。测试依赖注入代码:使用模拟框架测试注入过程。 C++ 框架的依赖注入最佳实践 …

    2025年12月18日
    000
  • C++ 框架中依赖注入的未来展望

    依赖注入在 c++++ 框架中的未来展望:松散耦合、可重用、可扩展、可测试。流行框架:boost.di、cpp-di、fruit。实战案例:使用 cpp-di 注入文件系统操作系统的依赖项。未来趋势:编译时 di、类型安全 di、领域特定 di 框架。 C++ 框架中依赖注入的未来展望 引言 依赖注…

    2025年12月18日
    100
  • C++ 框架中依赖注入的持续集成与部署实践

    使用依赖注入进行持续集成与部署:在持续集成中,di 允许通过依赖接口而不是具体实现,隔离和测试依赖项。在部署中,di 允许使用容器管理依赖项配置和生存期,根据环境动态创建和配置实例。 标题:C++ 框架中依赖注入的持续集成与部署实践 在现代软件开发中,依赖注入 (DI) 已成为管理 C++ 应用程序…

    2025年12月18日
    000
  • 如何理解 C++ 框架中的依赖注入?

    在 c++++ 框架中,依赖注入 (di) 是将依赖关系创建与使用分离的设计模式,提高代码可测试性和可维护性。di 在 c++ 中可通过构造函数注入、设值器注入和工厂方法来实现。本指南提供了实战案例,展示了如何使用 usermanager 类及其 userrepository 依赖关系。di 优势包…

    2025年12月18日
    000

发表回复

登录后才能评论
关注微信