Class yii\di\Instance
Inheritance | yii\di\Instance |
---|---|
Available since version | 2.0 |
Source Code | https://github.com/yiisoft/yii2/blob/master/framework/di/Instance.php |
Instance represents a reference to a named object in a dependency injection (DI) container or a service locator.
You may use get() to obtain the actual object referenced by $id.
Instance is mainly used in two places:
- When configuring a dependency injection container, you use Instance to reference a class name, interface name or alias name. The reference can later be resolved into the actual object by the container.
- In classes which use service locator to obtain dependent objects.
The following example shows how to configure a DI container with Instance:
$container = new \yii\di\Container;
$container->set('cache', [
'class' => 'yii\caching\DbCache',
'db' => Instance::of('db')
]);
$container->set('db', [
'class' => 'yii\db\Connection',
'dsn' => 'sqlite:path/to/file.db',
]);
And the following example shows how a class retrieves a component from a service locator:
class DbCache extends Cache
{
public $db = 'db';
public function init()
{
parent::init();
$this->db = Instance::ensure($this->db, 'yii\db\Connection');
}
}
Public Properties
Property | Type | Description | Defined By |
---|---|---|---|
$id | string | The component ID, class name, interface name or alias name | yii\di\Instance |
$optional | boolean | If null should be returned instead of throwing an exception | yii\di\Instance |
Public Methods
Method | Description | Defined By |
---|---|---|
__set_state() | Restores class state after using var_export() . |
yii\di\Instance |
ensure() | Resolves the specified reference into the actual object and makes sure it is of the specified type. | yii\di\Instance |
get() | Returns the actual object referenced by this Instance object. | yii\di\Instance |
of() | Creates a new Instance object. | yii\di\Instance |
Protected Methods
Method | Description | Defined By |
---|---|---|
__construct() | Constructor. | yii\di\Instance |
Property Details
The component ID, class name, interface name or alias name
If null should be returned instead of throwing an exception
Method Details
Constructor.
protected void __construct ( $id, $optional = false ) | ||
$id | string | The component ID |
$optional | boolean | If null should be returned instead of throwing an exception |
Restores class state after using var_export()
.
See also var_export().
public static yii\di\Instance __set_state ( $state ) | ||
$state | array | |
throws | yii\base\InvalidConfigException | when $state property does not contain |
---|
Resolves the specified reference into the actual object and makes sure it is of the specified type.
The reference may be specified as a string or an Instance object. If the former, it will be treated as a component ID, a class/interface name or an alias, depending on the container type.
If you do not specify a container, the method will first try Yii::$app
followed by Yii::$container
.
For example,
use yii\db\Connection;
// returns Yii::$app->db
$db = Instance::ensure('db', Connection::className());
// returns an instance of Connection using the given configuration
$db = Instance::ensure(['dsn' => 'sqlite:path/to/my.db'], Connection::className());
public static object ensure ( $reference, $type = null, $container = null ) | ||
$reference | object|string|array|static | An object or a reference to the desired object.
You may specify a reference in terms of a component ID or an Instance object.
Starting from version 2.0.2, you may also pass in a configuration array for creating the object.
If the "class" value is not specified in the configuration array, it will use the value of |
$type | string | The class/interface name to be checked. If null, type check will not be performed. |
$container | yii\di\ServiceLocator|yii\di\Container | The container. This will be passed to get(). |
return | object | The object referenced by the Instance, or |
---|---|---|
throws | yii\base\InvalidConfigException | if the reference is invalid |
Returns the actual object referenced by this Instance object.
public object get ( $container = null ) | ||
$container | yii\di\ServiceLocator|yii\di\Container | The container used to locate the referenced object.
If null, the method will first try |
return | object | The actual object referenced by this Instance object. |
---|
Creates a new Instance object.
public static yii\di\Instance of ( $id, $optional = false ) | ||
$id | string | The component ID |
$optional | boolean | If null should be returned instead of throwing an exception |
return | yii\di\Instance | The new Instance object. |
---|