PHPackages                             liuitt/fw-component-container - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [Framework](/categories/framework)
4. /
5. liuitt/fw-component-container

ActiveLibrary[Framework](/categories/framework)

liuitt/fw-component-container
=============================

The Liuitt Framework's Container Component.

011PHP

Since Feb 26Pushed 10y ago1 watchersCompare

[ Source](https://github.com/liuitt/fw-component-container)[ Packagist](https://packagist.org/packages/liuitt/fw-component-container)[ RSS](/packages/liuitt-fw-component-container/feed)WikiDiscussions master Synced 4w ago

READMEChangelogDependenciesVersions (1)Used By (0)

Liuitt Container
================

[](#liuitt-container)

O Componente "Container" para o Framework Liuitt.

Este componente é utilizado para Injeção de Dependências de uma forma simples e prática.

Veja os exemplos a seguir para tirar suas conclusões!

Instalação via Composer
-----------------------

[](#instalação-via-composer)

Para instalar este Componente via Composer, execute o comando:

```
composer require liuitt/fw-component-container --prefer-dist dev-master
```

**IMPORTANTE** Verifique se você precisa de permissão para utilizar o composer.

Utilização
----------

[](#utilização)

Uma vez instalado, lembre-se de certificar se o Autoloader do Composer está incluído em seu script.

```
include 'vendor/autoload.php';
```

Exemplos
--------

[](#exemplos)

Para fins didáticos de ilustração, todos os exemplos documentados a seguir utilizam duas classes simples:

```
class Produto
{
    private $modelo;
    private $fabricante;

    public function __construct($modelo, $fabricante)
    {
        $this->modelo = $modelo;
        $this->fabricante = $fabricante;
    }
}

class Carrinho
{
    private $produto;

    public function __construct(Produto $produto)
    {
        echo var_export($produto, true);
    }
}
```

### Container::\_\_construct()

[](#container__construct)

Para utilizar basta instanciar o Componente **Container** sem passar argumentos para o Construtor:

```
use Liuitt\Component\Container;
$container = new Container();
```

### Container::register(String $alias, Callback $callback)

[](#containerregisterstring-alias-callback-callback)

Para registrar um objeto informe um "Alias" que será usado posteriormente para "resolver|recuperar" o objeto e uma Função Anônima:

```
$container->register('Celular', function(){
    return new Produto('Nokia 1520', 'Microsoft');
});
```

No exemplo acima, foi criado um **Registro** com o nome 'Celular', que retornará um objeto Produto com modelo **Nokia 1520** e fabricante **Microsoft**.

Alternativamene você poderá utilizar chamadas estáticas:

```
Container::register('Tablet', function(){
    return new Produto('Asus Fonepad 7', 'Asus');
});
```

### Container::resolve(String $alias)

[](#containerresolvestring-alias)

Para resolver um Registro você deverá informar o nome registrado para o mesmo:

```
$celular = $container->resolve('Celular');
```

ou estaticamente:

```
$tablet = Container::resolve('Tablet');
```

Inspecionando as variáveis **$celular** e **$tablet**,

```
echo '';
echo var_export($celular, true) . PHP_EOL;
echo var_export($tablet, true) . PHP_EOL;
```

você deverá ver algo como:

```
Produto::__set_state(array(
   'modelo' => 'Nokia 1520',
   'fabricante' => 'Microsoft',
))
Produto::__set_state(array(
   'modelo' => 'Asus Fonepad 7',
   'fabricante' => 'Asus',
))

```

### Container::resolveWith(String $alias, Array $args)

[](#containerresolvewithstring-alias-array-args)

Permite passar argumentos no momento em que um Registro é resolvido. No entanto, estes DEVEM ser informados na Função Anônima no momento que algo é registrado.

**Registrando com argumentos anonimamente**

```
Container::register('Celulares', function($modelo, $fabricante){
    return new Produto($modelo, $fabricante);
});
```

**Resolvendo com argumentos**

```
$iphone = $container->resolveWith('Celulares', ['iPhone S6', 'Apple'])
```

ou estaticamente

```
$galaxy = Container::resolveWith('Celulares', ['Samsung Galaxy', 'Samsung']);
```

Inspecionando as variáveis **$iphone** e **$galaxy**,

```
echo var_export($iphone, true) . PHP_EOL;
echo var_export($galaxy, true) . PHP_EOL;
```

você deverá ver algo como:

```
Produto::__set_state(array(
   'modelo' => 'iPhone S6',
   'fabricante' => 'Apple',
))
Produto::__set_state(array(
   'modelo' => 'Samsung Galaxy',
   'fabricante' => 'Samsung',
))

```

###  Health Score

20

—

LowBetter than 13% of packages

Maintenance20

Infrequent updates — may be unmaintained

Popularity5

Limited adoption so far

Community7

Small or concentrated contributor base

Maturity41

Maturing project, gaining track record

 Bus Factor1

Top contributor holds 100% of commits — single point of failure

How is this calculated?**Maintenance (25%)** — Last commit recency, latest release date, and issue-to-star ratio. Uses a 2-year decay window.

**Popularity (30%)** — Total and monthly downloads, GitHub stars, and forks. Logarithmic scaling prevents top-heavy scores.

**Community (15%)** — Contributors, dependents, forks, watchers, and maintainers. Measures real ecosystem engagement.

**Maturity (30%)** — Project age, version count, PHP version support, and release stability.

### Community

Maintainers

![](https://www.gravatar.com/avatar/795345712d8b599b7d8e268dbd1f1af2fb14b033e07cf18c5636e1c9e855caec?d=identicon)[liuitt](/maintainers/liuitt)

---

Top Contributors

[![liuitt](https://avatars.githubusercontent.com/u/8432759?v=4)](https://github.com/liuitt "liuitt (18 commits)")

### Embed Badge

![Health badge](/badges/liuitt-fw-component-container/health.svg)

```
[![Health](https://phpackages.com/badges/liuitt-fw-component-container/health.svg)](https://phpackages.com/packages/liuitt-fw-component-container)
```

###  Alternatives

[laravel/socialite

Laravel wrapper around OAuth 1 &amp; OAuth 2 libraries.

5.7k104.3M836](/packages/laravel-socialite)[laravel/dusk

Laravel Dusk provides simple end-to-end testing and browser automation.

1.9k38.6M289](/packages/laravel-dusk)[nineinchnick/edatatables

Grid widget for the Yii Framework, wrapper for the DataTables jQuery plugin

173.2k](/packages/nineinchnick-edatatables)[link-cloud/fast-hyperf

LinkCloud Fast Hyperf

241.2k1](/packages/link-cloud-fast-hyperf)

PHPackages © 2026

[Directory](/)[Categories](/categories)[Trending](/trending)[Changelog](/changelog)[Analyze](/analyze)
