承接 jshannon63/cobalt 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

jshannon63/cobalt

Composer 安装命令:

composer require jshannon63/cobalt

包简介

A fast, autowired PSR-11 dependency injection container for PHP with cached resolution closures.

README 文档

README

CI codecov PHPStan PHP Version Latest Version on Packagist Software License

Cobalt — An Autowired Dependency Injection Container for PHP

Realized in fewer than 200 lines of source.

Well documented, perfect for building/learning.

100% line and method coverage on PHP 8.2, 8.3, and 8.4.

One of the fastest PHP dynamic autowired containers available.

Cobalt was created to push the performance limits of what a PHP-based dynamic autowired DI container can achieve. Container::class implements the PSR-11 ContainerInterface and provides many of the features found in more notable container projects. Resolution closures are cached after the first build, so subsequent lookups skip all reflection work. Cobalt and its simple, heavily commented source are perfect for learning, or for embedding inside projects and frameworks.

The Cobalt service container has the following features:

  1. Single class container implementing the PSR-11 ContainerInterface v2.
  2. ArrayAccess methods for container bindings.
  3. Constructor injection of type-hinted dependencies.
  4. Dependency injection through bind() method closures.
  5. Autowired dependency resolution using Reflection.
  6. Top-down inversion of control (IoC).
  7. Shared mode option (singleton only).
  8. Bind existing instances into the container.
  9. A self-binding global container instance.

Installation

composer require jshannon63/cobalt

Usage

Creating the container

use Jshannon63\Cobalt\Container;

// create a default (prototype) container
$app = new Container();

// or, create a singleton-only services container
$app = new Container('shared');

Binding into the container

Binding does not instantiate the class. Instantiation is deferred until the binding is requested from the container. bind() accepts three parameters: the abstract name, the concrete implementation, and a boolean for whether the binding is a singleton. The abstract name is free-form and acts as the key in the binding registry.

bind(string $abstract, mixed $concrete = null, bool $singleton = false): void

// a simple binding using only the class name
$app->bind(Foo::class);

// or, bind an interface with a desired concrete implementation —
// you can swap the concrete out in one place in your code.
$app->bind(FooInterface::class, Foo::class);

// or, bind an interface or other label to a closure to directly
// control dependency injection.
$app->bind(FooInterface::class, fn () => new Foo('123-456-7890'));

// or, use array access to bind a new instance directly.
$app['Foo'] = new Foo();

Resolving out of the container

$instance = resolve(string $id): mixed (resolve checks for an existing binding before instantiating)

$foo = $app->resolve(FooInterface::class);

// or
$foo = $app[FooInterface::class];

// or
$foo = $app->get(FooInterface::class);

Trying to resolve a missing binding throws NotFoundException per PSR-11.

Using the make() method

make() is bind() then resolve() — useful for one-shot instantiation.

$instance = make(string $abstract, mixed ...$args): mixed

$foo = $app->make(FooInterface::class, Foo::class);

Creating an alias to a binding

alias(string $alias, string $binding): void

Allows creating additional string IDs for accessing existing container bindings.

$app->alias('myfoo', FooInterface::class);

Binding an existing instance

Pass an object to bind() and Cobalt registers it as a singleton automatically (a pre-built instance is by definition shared).

$app->bind('Foo', new Foo);

Checking if a binding exists

$bool = has(string $abstract): bool

$bool = $app->has('Foo');

Getting the values of a single binding

$array = getBinding(string $abstract): array

$array = $app->getBinding($abstract);

Getting a list of bindings

$array = getBindings(): array

$array = $app->getBindings();

Development

Run the full quality bar locally:

composer install
composer check       # lint + analyse + test

Or individually:

composer test         # PHPUnit
composer lint         # Laravel Pint (PSR-12 + opinionated)
composer analyse      # PHPStan level 9

License

The MIT License (MIT). Please see License File for more information.

统计信息

  • 总下载量: 874
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 8
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 8
  • Watchers: 2
  • Forks: 1
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2017-11-15

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固