Есть несколько способов. Вы можете свернуть своих собственных помощников вида элемента (которые, я думаю, могут стать довольно неуклюжими).
Или ... вы можете использовать видовой скрипт для формы, например так (очень простой пример):
class Your_Form extends Zend_Form
{
public function init()
{
$this->setDecorators( array(
'PrepareElements',
array( 'ViewScript', array( 'viewScript' => 'path/to/viewscript.phtml' ) )
) );
// only use basic decorators for elements
$decorators = array(
'ViewHelper',
'Label',
'Errors'
);
// create some element
$someElement = new Zend_Form_Element_Text( 'someElement' );
// set the basic decorators for this element and set a css class
$someElement->setDecorators( $decorators )
->setAttrib( 'class', 'someCssClass' );
// add (potentially multiple) elements to this from
$this->addElements( array(
$someElement
) );
}
}
См. Раздел стандартные декораторы о PrepareElements , чтобы узнать, почему необходимо использовать декоратор PrepareElements для формы при использовании декоратора ViewScript.
Тогда в просмотре:
<?
// the form is available to the viewscript as $this->element
$form = $this->element;
?>
<!-- put whatever html you like in this script and render the basic element decorators seperately -->
<div>
<? if( $form->someElement->hasErrors() ): ?>
<?= $form->someElement->renderErrors() ?>
<? endif; ?>
<?= $form->someElement->renderLabel(); ?>
<?= $form->someElement->renderViewHelper(); ?>
</div>