Guia Rápido Zend_Layout
Há dois casos de uso primários para Zend_Layout: com o
MVC do Zend Framework, e sem.
Scripts de Layout
Em ambos os casos, entretanto, você precisará criar um script de layout.
Scripts de layout simplesmente utilizam Zend_View (ou
qualquer outra implementação de view que você esteja usando). Variáveis de layout são
registradas com um marcador
Zend_Layout, e podem ser acessadas via helper de marcador
ou buscando-as como propriedades de objeto do objeto layout via helper de layout.
Como um exemplo:
Meu Site
layout()->content;
// busca a chave 'foo' usando um helper marcador:
echo $this->placeholder('Zend_Layout')->foo;
// busca o objeto de layout e recupera várias chaves dele:
$layout = $this->layout();
echo $layout->bar;
echo $layout->baz;
?>
]]>
Como Zend_Layout utiliza Zend_View para
renderização, Você pode também usar quaisquer helpers de view registradas, e também
ter acesso a quaisquer variáveis de view associadas. Particularmente útil são os
vários helpers marcadores,
que permitem a você recuperar conteúdo para áreas tais como a seção <head>,
navegação, etc.:
headTitle() ?>
headScript() ?>
headStyle() ?>
render('header.phtml') ?>
placeholder('nav') ?>
layout()->content ?>
render('footer.phtml') ?>
]]>Usando Zend_Layout com o MVC do Zend FrameworkZend_Controller oferece um rico conjunto de funcionalidades
para extensão por meio de seus front controller plugins e action controller helpers.
Zend_View também tem helpers. Zend_Layout
toma vantagem desses diversos pontos de extensão quando usado com os
componentes MVC.
Zend_Layout::startMvc() cria uma instância de
Zend_Layout com qualquer configuração opcional que
você fornecer. Ele registra então um front controller plugin que renderiza o
layout com qualquer conteúdo de aplicação uma vez que o laço de despacho foi feito,
e registra um action helper para permitir o acesso ao objeto layout a partir de seus
action controllers. Adicionalmente, você pode a qualquer tempo pegar a instância de
dentro de um view script usando o view helper Layout.
Primeiro, dê uma olhada em como inicializar Zend_Layout
para uso com o MVC:
startMvc() pode tomar uma matriz opcional de opções ou
um objeto Zend_Config para customizar a instância; essas
opções são detalhadas nesta seção.
Em um action controller, você pode então acessar a instância de layout como um action
helper:
_helper->layout->disableLayout();
}
public function bazAction()
{
// usa um script de layout diferente com este action:
$this->_helper->layout->setLayout('foobaz');
};
}
]]>
Em seus view scripts, você pode então acessar o objeto de layout via view helper
Layout. Esse view helper é levemente diferente dos outros
no que toca a não tomar argumentos, e retornar um objeto ao invés de um valor
string. Isso permite que você imediatamente chame métodos no objeto de layout:
layout()->setLayout('foo'); // configura layout alternativo ?>
]]>
A qualquer tempo, você pode buscar a instância de Zend_Layout
registrada com MVC via método estático
getMvcInstance():
Finalmente, o front controller plugin de Zend_Layout tem
uma importante característica em adição a renderização do layout: ele recupera
todos os segmentos nomeados do objeto de resposta e associa variáveis,
associando o segmento 'default' a variável 'content'. Isso permite a você acessar
o conteúdo de sua aplicação e renderizá-lo em seus view scripts.
Como um exemplo, diremos que seu código primeiro ativa
FooController::indexAction(), que renderiza algum
conteúdo para o segmento de resposta padrão, e então prossegue para
NavController::menuAction(), que renderiza conteúdo
para o segmento de resposta 'nav'. Finalmente, você prossegue para
CommentController::fetchAction() e busca alguns comentários,
mas renderizar isso para o segmento de resposta é bom (o que adiciona conteúdo
aquele segmento). Seu view script poderia então renderizar cada um separadamente: