Angular 14 新的 inject 函数介绍

举报
Jerry Wang 发表于 2023/01/30 08:38:19 2023/01/30
【摘要】 inject() 函数将 InjectionToken 作为参数,并从当前 active 的注入器返回该 InjectionToken 的值。 简而言之,这是另一种不使用 constructor injection 而仍然能够获取依赖项的方法。

Angular 14 提供了一些非常有趣的特性:类型化表单(typed forms)、独立组件(standalone components),以及本文将要介绍的内容,即在所谓的构造器阶段(constructor phase) 使用 inject 函数的能力。

什么是 inject 函数

inject() 函数将 InjectionToken 作为参数,并从当前 active 的注入器返回该 InjectionToken 的值。 简而言之,这是另一种不使用 constructor injection 而仍然能够获取依赖项的方法。

看个具体的例子:

什么是 constructor phase

构造器阶段意味着构造器函数作用域( constructor function scope)和字段初始化器(field initializers)。 这意味着不能在 @Input() 设置器或任何其他函数或生命周期挂钩中调用 inject() 函数。

下图 title setter 中视图调用 inject 函数,会出现 Angular 编译错误。

使用 inject 函数降低 Component 的复杂度

假设我们需要在组件中添加一个路由器路径(router path)参数,以便从 API 获取实体详细信息。

让我们看看不使用 inject() 函数(或任何其他外观服务即 facade service)的情况。

上面的例子是传统的基于构造函数的注入实现方式,存在三个缺陷:

  • 该 Component 依赖于 HttpClient(或执行 API 调用的其他外观服务)。
  • 该 Component 依赖于 ActivatedRoute。
  • 在组件实现中有业务逻辑,它应该只负责显示 UI,而不是担心如何获取数据。

使用 inject 函数,改进后的实现:

在上面的代码中,组件忽略了从服务器获取实体所需的内容。 它所知道的是它现在有一个名为 entity$ 的属性,用于存储 Observable<Entity>。Component 现在根本不需要构造函数注入。这允许组件符合了设计的单一职责准则,而不是组件+数据聚合器。

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。