在开发过程中,依赖注入(dependency injection, di)是非常常见的一种设计模式。它可以帮助我们管理对象之间的依赖关系,提高代码的可维护性和可测试性。然而,在使用传统的di容器时,我常常遇到一个问题:ide无法识别从容器中获取的对象类型,这导致无法提供智能提示和静态分析,严重影响了我的开发效率。
为了解决这个问题,我尝试了mrclay/props-dic这个库。mrclay/props-dic提供了一种全新的方式来访问容器中的值:通过自定义的属性和方法名。这不仅让IDE能够识别返回值的类型,还能提供更好的智能提示和静态分析功能。
使用composer安装mrclay/props-dic非常简单,只需运行以下命令:
composer require mrclay/props-dic
让我们来看一个简单的例子,展示如何使用mrclay/props-dic:
/** * @property-read Foo $foo * @method Foo new_foo() */ class MyContainer extends PropsContainer { public function __construct() { $this->foo = function (MyContainer $c) { return new Foo(); }; } } $c = new MyContainer(); $foo1 = $c->foo; // 你的IDE会知道这是一个Foo实例 $foo2 = $c->new_foo(); // 一个新的Foo实例 $foo3 = $c->foo; // 与$foo1相同
在这个例子中,我们通过自定义的属性$foo和方法new_foo()来访问容器中的值。IDE能够识别这些属性和方法的类型,并提供相应的智能提示和静态分析。
另一个更复杂的例子展示了如何管理多个依赖:
/** * @property-read string $style * @property-read Dough $dough * @property-read Cheese $cheese * @property-read Pizza $pizza * @method Slice new_slice() */ class PizzaServices extends PropsContainer { public function __construct() { $this->style = 'deluxe'; $this->dough = function (PizzaServices $c) { return new Dough(); }; $this->setFactory('cheese', 'CheeseFactory::getCheese'); $this->pizza = function (PizzaServices $c) { $pizza = new Pizza($c->style, $c->cheese); $pizza->setDough($c->dough); return $pizza; }; $this->slice = function (PizzaServices $c) { return $c->pizza->getSlice(); }; } } $c = new PizzaServices; $c->pizza; // 第一次解析并缓存cheese和dough。 $c->pizza; // 与上面的pizza实例相同(没有调用工厂)。 $c->new_slice(); // 一个新的Slice实例 $c->new_slice(); // 另一个新的Slice实例
在这个例子中,我们通过自定义的属性和方法来管理多个依赖关系,IDE能够提供更好的类型提示和静态分析功能。
使用mrclay/props-dic库,我不仅解决了IDE无法识别返回值类型的问题,还提升了开发效率和代码质量。它通过自定义属性和方法名访问值的方式,使得依赖注入变得更加直观和易于管理。如果你在使用依赖注入时也遇到类似的问题,不妨尝试一下mrclay/props-dic。
© 版权声明
文章版权归作者所有,未经允许请勿转载。
THE END