Download the PHP package opxcore/container without Composer
On this page you can find all versions of the php package opxcore/container. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download opxcore/container
More information about opxcore/container
Files in opxcore/container
Package container
Short Description The OpxCore dependency injection container.
License MIT
Homepage https://opxcore.com
Informations about the package container
Dependency injection container
Introduction
The dependency injection container is a powerful tool for managing class dependencies and performing dependency injection. Class dependencies are "injected" into the class via the constructor and resolved by the container.
Example:
Calling $container->make(Controller::class)
would be equal to new Controller(new Repository)
. This amazing feature
resolves all dependency injections automatically with zero-config. For this example if
Repository
have its own dependency, it will be resolved the same.
Installing
composer require opxcore/container
Creating
You can create a container several ways:
or
In all of this cases Container::getContainer()
will always return the same container instance.
If you want to create and handle a container (or several containers) by yourself just use
$container = new Container
and handle this container instance as you want.
Registering a binding with the container
Basic binding to container looks like:
$abstract
is a string containing class name or shorthand for a name to be resolved.
$concrete
is a string containing class name or callable
returning object for a name to be resolved to. Container
instance and parameters will be passed to callable during resolving.
$parameters
is an array or callable returning array with parameters used for resolving (see below). Default value
is null
means no parameters will be bound.
Examples:
Simple usage
Binding interfaces to its realizations
We have Controller
class what depends on some RepositoryInterface
and FileRepository
implementing it:
Now we bind FileRepository::class
to RepositoryInterface::class
so when some class depends on RepositoryInterface
it will be resolved to FileRepository
and path
argument will be passed into with specified value.
Binding parameters
You can bind parameters into the container fo resolving. It can be used as primitives binding or class binding:
Singleton
The singleton method binds a class or interface into the container that should be resolved once. First time it will be resolved and stored in the container, so other times the same object instance will be returned on subsequent calls into the container.
Alias
Alias is another name for resolving.
Instance
You can register any object or value into the container.
Resolving
When resolving some name, you can pass parameters to make()
function to attach it for resolving subject.
Sequence of making subject
When resolving some subject, the container checks for registered aliases first, checks for registered instances and resolves using reflections.