Pular para o conteúdo

Componentes

Componente é a parte principal na construção de aplicações Yii. Componentes são instâncias de [[yii\base\Component]], ou uma classe estendida. As três características principais que os componentes fornecem a outras classes são:

Separadamente e combinadas, essas características fazem com que as classes no Yii sejam muito mais customizáveis e fáceis de usar. Por exemplo, o [[yii\jui\DatePicker|widget date picker]], um componente de interface do usuário, pode ser usado na view (visão) para gerar um date picker interativo:

use yii\jui\DatePicker;
echo DatePicker::widget([
'language' => 'ru',
'name' => 'country',
'clientOptions' => [
'dateFormat' => 'yy-mm-dd',
],
]);

Os widgets são facilmente escritos porque a classe estende de [[yii\base\Component]].

Enquanto os componentes são muito poderosos, eles são um pouco mais pesados do que um objeto normal, devido ao fato de que é preciso memória e CPU extra para dar suporte às funcionalidades de evento e de behavior em particular. Se o seu componente não precisa dessas duas características, você pode considerar estender a sua classe de componente de [[yii\base\BaseObject]] em vez de [[yii\base\Component]]. Se o fizer, fará com que seus componentes sejam tão eficientes como objetos normais do PHP, mas com um suporte adicional para propriedades.

Ao estender a classe de [[yii\base\Component]] ou [[yii\base\BaseObject]], é recomendado que você siga as seguintes convenções:

  • Se você sobrescrever o construtor, declare um parâmetro $config como último parâmetro do construtor, e em seguida passe este parâmetro para o construtor pai.
  • Sempre chame o construtor pai no final do seu construtor reescrito.
  • Se você sobrescrever o método [[yii\base\BaseObject::init()]], certifique-se de chamar a implementação pai do init no início do seu método init.

Por Exemplo:

<?php
namespace yii\components\MyClass;
use yii\base\BaseObject;
class MyClass extends BaseObject
{
public $prop1;
public $prop2;
public function __construct($param1, $param2, $config = [])
{
// ... initialization before configuration is applied
parent::__construct($config);
}
public function init()
{
parent::init();
// ... initialization after configuration is applied
}
}

Seguindo essas orientações fará com que seus componentes sejam configuráveis quando forem criados. Por Exemplo:

$component = new MyClass(1, 2, ['prop1' => 3, 'prop2' => 4]);
// alternatively
$component = \Yii::createObject([
'class' => MyClass::class,
'prop1' => 3,
'prop2' => 4,
], [1, 2]);

Informação: Embora a forma de chamar [[Yii::createObject()]] pareça ser mais complicada, ela é mais poderosa porque ela é aplicada no topo de um container de injeção de dependência.

A classe [[yii\base\BaseObject]] impõe o seguinte ciclo de vida do objeto:

  1. Pré-inicialização dentro do construtor. Você pode definir valores de propriedade padrão aqui.
  2. Configuração de objeto via $config. A configuração pode sobrescrever o valor padrão configurado dentro do construtor.
  3. Pós-inicialização dentro do [[yii\base\BaseObject::init()|init()]]. Você pode sobrescrever este método para executar checagens e normalização das propriedades.
  4. Chamadas de método de objeto.

Os três primeiros passos acontecem dentro do construtor do objeto. Isto significa que uma vez que você instanciar a classe (isto é, um objeto), esse objeto será inicializado adequadamente.