在自定义Zend_Form_Element中设置所选项目

时间:2010-04-20 18:23:37

标签: zend-framework zend-form-element

我创建了自己的小表单元素来输入时间。因为我在我的应用程序中的一些地方需要这个,所以我决定为它创建一个单独的元素。

这是代码所以fa:

class EventManager_Form_Element_Time extends Zend_Form_Element 
{
    public function init()
    {
        parent::init();
        $this->addDecorator('ViewScript', array(
            'viewScript' =>  'time.phtml'
        ));

        $this->addValidator(new Zend_Validate_Regex('/^[0-9]+:[0-9]+:[0-9]+$/'));
    }

    public function setValue($value)
    {
        if(is_array($value))
        {
            @list($hours, $minutes, $seconds) = $value;         
            $value = sprintf('%s:%s:%s', $hours, $minutes, $seconds);
        }

        return parent::setValue($value);
    }
}

我创建的相应视图脚本是:

    <?php @list($hours, $minutes, $seconds) = explode(':', $this->element->getValue()); ?>
<dt>
    <?= $this->formLabel($this->element->getName(), $this->element->getLabel()); ?>
</dt>
<dd>
    <select id="<?= $this->element->getName();?>">
        <option value="00">00</option>
        <option value="01">01</option>
        <option value="02">02</option>
        <option value="03">03</option>
        <option value="04">04</option>
        <option value="05">05</option>
        <option value="06">06</option>
        <option value="07">07</option>
        <option value="08">08</option>
        <option value="09">09</option>
        <option value="10">10</option>
        <option value="11">11</option>
        <option value="12">12</option>
        <option value="13">13</option>
        <option value="14">14</option>
        <option value="15">15</option>
        <option value="16">16</option>
        <option value="17">17</option>
        <option value="18">18</option>
        <option value="19">19</option>
        <option value="20">20</option>
        <option value="21">21</option>
        <option value="22">22</option>
        <option value="23">23</option>
    </select>
    <select id="<?= $this->element->getName();?>">
        <option value="00">00</option>
        <option value="15">15</option>
        <option value="30">30</option>
        <option value="45">45</option>
    </select>

    <input id="<?= $this->element->getName(); ?>" 
           type="hidden"
           name="<?= $this->element->getName(); ?>[]" 
           value="00" />



    <?php if(count($this->element->getMessages()) > 0): ?>
        <?= $this->formErrors($this->element->getMessages()); ?>
    <?php endif; ?>
</dd>

我的问题是,当我填充表单时,有时我想为我的selecbox设置一个默认选择值。问题是如何?

有没有人可以帮我解决这个问题?

感谢。

1 个答案:

答案 0 :(得分:1)

你可以这样做(未经测试):

控制器:

$form = new Your_Form();
$form->yourDateElement->setValue( '12:30:00' );
$this->view->form = $form;

查看:

<?= $this->form ?>

表单元素viewscript:

    <?php @list($hours, $minutes, $seconds) = explode(':', $this->element->getValue()); ?>
<dt>
    <?= $this->formLabel($this->element->getName(), $this->element->getLabel()); ?>
</dt>
<dd>
    <select id="<?= $this->element->getName();?>" name="<?= $this->element->getName(); ?>[]">
    <?
        for( $h = 0; $h < 24; $h++ ):
            $selected = $h == $hours ? ' selected="selected"' : '';
            $paddedHours = sprintf( '%02d', $h );
    ?>
        <option value="<?= $paddedHours ?>"<?= $selected ?>><?= $paddedHours ?></option>
    <? endfor; ?>
    </select>
    <select id="<?= $this->element->getName();?>" name="<?= $this->element->getName(); ?>[]">
    <?
        for( $m = 0; $m < 60; $m += 15 ):
            $selected = $m == $minutes ? ' selected="selected"' : '';
            $paddedMinutes = sprintf( '%02d', $m );
    ?>
        <option value="<?= $paddedMinutes ?>"<?= $selected ?>><?= $paddedMinutes ?></option>
    <? endfor; ?>
    </select>

    <input id="<?= $this->element->getName(); ?>" 
           type="hidden"
           name="<?= $this->element->getName(); ?>[]" 
           value="00" />



    <?php if(count($this->element->getMessages()) > 0): ?>
        <?= $this->formErrors($this->element->getMessages()); ?>
    <?php endif; ?>
</dd>

顺便说一句:
我认为这一切都不会那么容易。你看,你的viewscript有3个元素:2个选择和1个隐藏输入,但你的表单元素不考虑这些。

查看Matthew Weier O'Phinney's blog post如何创建复合表单元素。这应该会给你一些想法。