返回顶部
首页 > 资讯 > 精选 >VSCode中依赖注入的原理是什么
  • 409
分享到

VSCode中依赖注入的原理是什么

2023-07-05 02:07:57 409人浏览 薄情痞子
摘要

这篇文章主要介绍“vscode中依赖注入的原理是什么”,在日常操作中,相信很多人在VSCode中依赖注入的原理是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”VSCode中依赖注入的原理是什么”的疑惑有所

这篇文章主要介绍“vscode中依赖注入的原理是什么”,在日常操作中,相信很多人在VSCode中依赖注入的原理是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”VSCode中依赖注入的原理是什么”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

依赖注入做了什么

假设以下情况:

  • 服务模块 A,依赖服务 B;

  • 服务模块 B;

  • 功能模块 Feature,依赖服务 A 和 B;

按照普通的写法就是:

class B {}class A {    constructor() {        // 在 A 的构造器中 new B        this.b = new B();    }}class Feature {    constructor() {        this.a = new A();        this.b = new B();    }}// 使用时const feature = new Feature();

代码简单明了,存在一些问题,比如:如果 A 和 Feature 依赖的 B 需要是同一个实例,以上的写法将会初始化两个 B 实例。【推荐学习:vscode教程编程教学】

简单修改一下:

class A {    constructor(b: B) {        this.b = b;    }}class Feature {    constructor(a, b) {        this.a = a;        this.b = b;    }}// 使用时const b = new B();const a = new A(b);const feature = new Feature(a, b);

某个模块初始化时,先在外部将其所依赖的模块创建出来,通过参数的形式传入功能模块。这样的写法就是「依赖注入」。

现在这种写法的问题在于:手动传参的形式,必须人工保证 new 的顺序,即必须获得 a, b 实例才能执行 newFeature。

当依赖关系变得复杂时,创建一个功能模块之前很有可能需要无数个基础模块,这时候复杂度将会非常高。

想象一种模式:存在一个模块控制器,或者说「服务管理器」来管理这些依赖关系:

class Feature {    // 声明这个模块依赖 idA, idB    idA    idB}// 告知「服务管理器」,怎么找对应的模块services[idA] = A;services[idB] = B;// 使用时const feature = services.createInstance(Feature);

这个 services 承载的不就是之前的「手工」过程吗?
在 createInstance(Feature) 时,分析 Feature 所依赖的模块:

  • 如果所依赖的模块还未创建出实例,递归创建出该服务实例,最终返回;

  • 如果所依赖的模块已有实例,返回该实例;

  • 找齐后通过参数注入 Feature,完成初始化;
    VSCode 实现的正是这么一套「依赖注入体系」。

依赖注入怎么做?

要实现这样一套功能,大致需要:

  • 一个类如何声明其依赖的服务 id,即给定一个 类,外部如何知道他依赖了哪些服务?

  • 如何管理管理服务?

  • 如何创建某个模块?

下文会实现一个最简单的模型,涵盖主体流程。

添加依赖信息

如何给一个 类 打上烙印,声明它所依赖的服务呢?
将问题再次抽象:如何给一个类加上额外的信息?
其实,每个类在 es5 下都是 Function,而每个 Function 说到底也只是 Object ,只要给 Object 加上几个字段来标识所需要的服务 id,就可以完成所需要的功能。
通过 「参数装饰器」的写法,可以很容易做到这一点:

// 参数装饰器 const decorator = (    target: Object, // 被装饰的目标,这里为 Feature    propertyName: string,     index: number // 参数的位置索引) => {    target['deps'] = [{        index,        id: 'idA',    }];}class Feature {    name = 'feature';    a: any;    constructor(        // 参数装饰器        @decorator a: any,    ) {        this.a = a;    }}console.log('Feature.deps', Feature['deps']);// [{ id: 'idA', index: 0 }]

通过这种方式,通过 Feature (之后会称之为 构造器 ctor)就可以获取到 serviceId。

服务管理

使用 Map 来进行管理,一个 id 对应一个 服务 ctor。

class A {    name = 'a';}// 服务集class ServiceCollection {    // 服务集合    // key 为服务标识    // value 为 服务ctor    private entries = new Map<string, any>();    set(id: string, ctor: any) {        this.entries.set(id, ctor);       }    get(id: string): any {        return this.entries.get(id);    }}const services = new ServiceCollection();// 声明服务 A id 为 idAservices.set('idA', A);

现在,就可以通过 Feature 来找到所依赖的服务的构造器了

// 通过 Feature 找到所依赖的 Aconst serviceId = Feature['deps'][0].id; // idAconsole.log(    'Feature.deps',     services.get(serviceId) // A);

模块创建

具体思路为:

  • 如果所依赖的模块还未创建出实例,递归创建出该服务实例,最终返回;

  • 如果所依赖的模块已有实例,返回该实例;

  • 找齐后通过参数注入 Feature,完成初始化;

这里先上一个简单的 demo,只有一层的依赖(即所依赖的服务没有依赖其他服务),简单的讲,就是没有递归能力:

class InstantiationService {    services: ServiceCollection;    constructor(services: ServiceCollection) {        this.services = services;    }    createInstance(ctor: any) {        // 1. 获取 ctor 依赖的 服务id        // 结果为: ['idA']        const depIds = ctor['deps'].map((item: any) => item.id);        // 2. 获取服务 id 对应的 服务构造器        // 结果为:[A]        const depCtors = depIds.map((id: string) => services.get(id));        // 3. 获取服务实例        // 结果为: [ A { name: 'a'} ]        const args = depCtors.map((ctor: any) => new ctor());        // 4. 依赖的服务作为参数注入,实例化所需要模块        // 结果为:[ Feature { name: 'feature', a }]        const result = new ctor(...args);        return result;    }}const instantiation = new InstantiationService(services);// 使用时const feature = instantiation.createInstance(Feature);

要使用 Feature 时,只需要调用 createInstance,不用管他所依赖的服务是否被初始化,instantiation 帮我们做了这个事情。

到此,关于“VSCode中依赖注入的原理是什么”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

--结束END--

本文标题: VSCode中依赖注入的原理是什么

本文链接: https://lsjlt.com/news/349103.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • VSCode中依赖注入的原理是什么
    这篇文章主要介绍“VSCode中依赖注入的原理是什么”,在日常操作中,相信很多人在VSCode中依赖注入的原理是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”VSCode中依赖注入的原理是什么”的疑惑有所...
    99+
    2023-07-05
  • JavaScript中依赖注入的原理是什么
    这期内容当中小编将会给大家带来有关JavaScript中依赖注入的原理是什么,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。如下需求:假设已经有定义好的服务模块Key-Va...
    99+
    2024-04-02
  • laravel依赖注入原理是什么
    Laravel的依赖注入原理是通过容器(Container)来实现的。容器是一个管理依赖关系的工具,它可以创建和解析对象,并自动解决...
    99+
    2023-09-06
    laravel
  • spring依赖注入的原理是什么
    Spring依赖注入的原理是通过IOC(Inversion of Control)容器来实现的。IOC容器是Spring框架的核心,...
    99+
    2023-09-29
    spring
  • php依赖注入的原理是什么
    PHP依赖注入的原理是通过将一个对象的依赖关系通过构造函数、方法参数或者setter方法的方式进行传递。依赖注入的目的是解耦,使得代...
    99+
    2023-09-21
    php
  • angular依赖注入的原理是什么
    Angular的依赖注入(Dependency Injection)是一种设计模式,用于管理组件之间的依赖关系。它的原理是通过将组件...
    99+
    2023-09-21
    angular
  • laravel依赖注入的原理是什么
    Laravel的依赖注入原理是基于反射的。依赖注入是一种设计模式,它的目的是通过将依赖对象的实例传递给需要它们的对象,来解耦和提高代...
    99+
    2023-10-22
    laravel
  • VSCode中的依赖注入怎么实现
    这篇文章主要讲解了“VSCode中的依赖注入怎么实现”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“VSCode中的依赖注入怎么实现”吧!依赖注入介绍如果有这样一个模块 A,它的实现依赖另一个...
    99+
    2023-07-04
  • Spring框架实现依赖注入的原理是什么
    这篇文章主要介绍“Spring框架实现依赖注入的原理是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Spring框架实现依赖注入的原理是什么”文章能帮助大家解决问题。Spring 框架作为 Ja...
    99+
    2023-07-06
  • laravel中依赖注入指的是什么
    这篇文章给大家分享的是有关laravel中依赖注入指的是什么的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。laravel依赖注入一词是由Martin Fowler提出的术语,它是将组件注入到应用程序中的一种行为,...
    99+
    2023-06-22
  • Spring bean需要依赖注入的原因是什么
    这篇文章主要介绍“Spring bean需要依赖注入的原因是什么”,在日常操作中,相信很多人在Spring bean需要依赖注入的原因是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Spring bean...
    99+
    2023-06-20
  • php依赖注入指的是什么
    本篇内容介绍了“php依赖注入指的是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!在PHP中,依赖注入是指对类的依赖通过构造器完成自动注...
    99+
    2023-06-29
  • Angular中依赖注入模式是什么
    这篇文章主要介绍Angular中依赖注入模式是什么,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!Angular 依赖注入模式依赖注入: Dependency Injection 简称 DI依赖注入模式要解决的问题开发...
    99+
    2023-06-14
  • Spring的依赖注入机制是什么
    Spring的依赖注入(Dependency Injection,DI)机制是一种设计模式,用于实现对象之间的解耦和组件的松耦合。它...
    99+
    2023-09-17
    Spring
  • Java依赖注入的方式是什么
    这篇“Java依赖注入的方式是什么”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Java依赖注入的方式是什么”文章吧。Spr...
    99+
    2023-07-02
  • php依赖注入是什么意思
    本文操作环境:Windows10系统、PHP7.1版、Dell G3电脑。php依赖注入是什么意思 依赖注入其实本质上是指对类的依赖通过构造器完成自动注入,例如在控制器架构方法和操作方法中一旦对参数进行对象类型约束则会自动触发依赖注入...
    99+
    2021-05-31
    php
  • Spring框架实现依赖注入的原理
    目录什么是依赖注入实现原理IOC容器Bean定义依赖注入构造函数注入Setter方法注入字段注入生命周期回调注解总结Spring 框架作为 Java 开发中最流行的框架之一,其核心特...
    99+
    2023-05-15
    Spring依赖注入 Spring依赖注入的方式 Spring依赖注入原理
  • Web前端中依赖注入的方法是什么
    本篇内容介绍了“Web前端中依赖注入的方法是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、什么是IoCIoC 的全称叫做 Inver...
    99+
    2023-06-04
  • go语言依赖注入指的是什么
    本篇内容介绍了“go语言依赖注入指的是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!在go语言中,依赖注入(DI)是一种解耦组件之间依赖...
    99+
    2023-07-05
  • Java Spring中各依赖注入注解的区别是什么
    本篇文章给大家分享的是有关Java Spring中各依赖注入注解的区别是什么,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。Spring对于Be...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作