介绍
在阅读Visual code源码时发现有若干"@IContextKeyService"的代码,@后面紧跟需要注入的服务,一开始比较疑惑,不知道该对象是如何传入MenuItemAction的对象中的(实例化此类的时候并没有发现传入该对象),后面通过查询资料可知,这里使用依赖注入的方式注入contextKeyService对象,在软件工程中,依赖注入是被注入的对象接收其依赖的其他对象的技术。这些其他对象称为依赖项。在典型的“应用”关系中,接收对象称为客户端,而传递的(即“注入”)对象称为service。将服务传递给客户端的代码可以是各种东西需要自己定义,该工具称为注入器。注入程序会告诉客户端要使用的服务,而不是由客户端指定它将使用的服务。“注入”是指将依赖项(服务)传递给即将使用该依赖项的对象(客户端)。依赖项注入的目的是实现对象构造和使用关注点的分离。这可以提高可读性和代码重用。
依赖注入是控制反转(类似于好莱坞原则:不要打电话给我们,我们会打电话给您)的更广泛技术的一种形式。想要调用某些服务的客户端不必知道如何构造那些服务。相反,客户端将提供服务的责任委托给外部代码(注入程序)。不允许客户端调用注入器代码;构造服务的是注入器。然后,注入程序将服务注入(传递)到客户端中,该服务可能已经存在或可能由注入程序构造。然后,客户端使用服务。这意味着客户端不需要了解注入器,不需要知道如何构造服务,甚至不需要了解其正在使用的实际服务。客户端只需要知道服务的公共接口,因为它们定义了客户端如何使用服务。这可将“使用服务”的责任与“构建服务”的责任分开。
既然该技术拥有诸多优点,那能否在Python上实现它,并应用于自己的代码中呢?首先Google一下看看有没有现成的轮子(毕竟自己造轮子费时费力问题还多),通过Google找到Python上有一个依赖注入框架实现名为Injector。
export class MenuItemAction extends ExecuteCommandAction {
readonly item: ICommandAction