sergix44 / container
一个简单快速的服务容器
3.1.0
2024-06-18 12:52 UTC
Requires
- php: ^8.1
- ext-reflection: *
- psr/container: ^1.1|^2.0
Requires (Dev)
- pestphp/pest: ^2.0
- php-di/php-di: ^7.0
- vimeo/psalm: ^5.13
Provides
- psr/container-implementation: ^1.1|^2.0
README
一个简单、快速且遵循PSR-11规范的服务容器。
非常适合从依赖注入中受益的库,通过委托功能可以与其他框架集成。
🚀 安装
composer require sergix44/container
🔧 使用
注册一个定义
$container = new \SergiX44\Container\Container(); $container->bind(ServiceInterface::class, MyService::class); $instance = $container->get(ClassThatUseMyService::class);
注册一个共享定义(第一次解析将被缓存,并返回相同的实例)
$container = new \SergiX44\Container\Container(); $container->singleton(ServiceInterface::class, MyService::class); $instance = $container->get(ClassThatUseMyService::class);
您可以将工厂定义为闭包
$container = new \SergiX44\Container\Container(); $value = 'dynamic'; // factory $container->bind(ServiceInterface::class, function (\Psr\Container\ContainerInterface $container) use ($value) { return new MyService($container->get(AnotherService::class), $value); }); // shared/singleton $container->singleton(FooServiceInterface::class, function (\Psr\Container\ContainerInterface $container) { return new FooService($container->get(ServiceInterface::class)); }); $instance = $container->get(ClassThatUseMyService::class);
您可以设置一个已解析的实例
$container = new \SergiX44\Container\Container(); $service = new MyService(); $container->set(ServiceInterface::class, $service); // or even as string: // $container->set('service', $service); // $service = $container->get('service'); $instance = $container->get(ClassThatUseMyService::class);
它还可以用于在任何可调用内部注入参数
// InvokableClass.php class InvokableClass { public function __invoke(ServiceInterface $service) { // } } // ClassAndMethod.php class ClassAndMethod { public function method(ServiceInterface $service) { // } } // -- $container = new \SergiX44\Container\Container(); $container->bind(ServiceInterface::class, MyService::class); $result = $container->call(InvokableClass::class); // calls __invoke $result = $container->call(new InvokableClass()); // calls __invoke $result = $container->call([ClassAndMethod::class, 'method']); // calls method $result = $container->call([new ClassAndMethod(), 'method']); // calls method $result = $container->call(function (ServiceInterface $service) { // });
您还可以使用关联数组传递任意参数
// InvokableClass.php class InvokableClass { public function __invoke(ServiceInterface $service, string $a, int $b) { // } } $container = new \SergiX44\Container\Container(); // map parameter name => value $result = $container->call(InvokableClass::class, ['a' => 'foo', 'b' => 123]); // positional $result = $container->call(InvokableClass::class, ['foo', 123]);
您还可以混合位置和关联表示法
// InvokableClass.php class InvokableClass { public function __invoke(ServiceInterface $service, string $a, int $b) { // same result: b=456 and a=foo } } $container = new \SergiX44\Container\Container(); $result = $container->call(InvokableClass::class, ['b' => 456, 'foo']);
⚗️ 测试
运行测试套件
vendor/bin/pest
🏅 致谢
📖 许可证
MIT许可证(MIT)。请参阅许可证文件获取更多信息。