Na construção de um website com camadas MVC usando Zendo Framework,
os scripts de visualização serão tipicamente apenas um fragmento de HTML
pertinente à ação solicitada. Por exemplo, se você tivesse a ação
"/user/list
", você poderia criar um script de vizualização que
percorresse os usuários e apresentasse uma lista desordenada:
<h2>Usuários</h2> <ul> <?php if (!count($this->users)): ?> <li>Nenhum usuário encontrado</li> <?php else: ?> <?php foreach ($this->users as $user): ?> <li> <?php echo $this->escape($user->fullname) ?> (<?php echo $this->escape($user->email) ?>) </li> <?php endforeach ?> <?php endif ?> </ul>
Uma vez que este é apenas um fragmento de HTML, esta página não é válida; está faltando uma declaração DOCTYPE e as tags de abertura de HTML e BODY. A questão é: onde elas serão criadas?
Nas versões anteriores do Zend Framework, desenvolvedores muitas vezes criaram scripts de vizualização para "cabeçalho" e "rodapé" que continham esses artefatos, e então seriam renderizados em cada script de vizualização. Enquanto essa metodologia funcionou, ela também gerou dificuldades de refatoração mais tarde, ou para criar conteúdos compostos pela chamada de múltiplas ações.
O padrão de projeto Two Step View explica muitos dos problemas apresentados. Nesse padrão, a vizualização "aplicação" é criada primeiro, depois introduzida na visualização "página" e depois é apresentada ao cliente. A visualização página pode ser pensada como um site-modelo ou layout, e teria elementos em comum utilizados em várias páginas.
Dentro do Zend Framework, o Zend_Layout
implementa o padrão Two Step
View.