Zend Form:Checkbox元素显示为隐藏字段?

时间:2009-12-22 00:14:28

标签: zend-framework checkbox zend-form zend-form-element

我想在表单中添加一个简单的复选框:

$element = new Zend_Form_Element_Checkbox('dont');
$element->setDescription('Check this box if you don\'t want to do this action.');
$form->addElement($element);

然而,这就是html的样子:

<dt id="dont-label">&nbsp;</dt>
<dd id="dont-element">
    <input type="hidden" name="dontAttach" value="0">
    <input type="checkbox" name="dontAttach" id="dontAttach" value="1">
    <p class="description">Don't attach a bulletin. I only want to send an email.</p>
</dd>

这个问题是我使用jQuery来隐藏DT中标签为&nbsp;的所有DT / DD以及DD中的隐藏元素(所以我的html将验证并隐藏元素不占用页面上的空间)。有没有办法使用Zend_Form_Element_Checkbox而不必显示隐藏的输入元素?我宁愿不搞乱我的jQuery代码来添加更多警告,但如果必须,我会这样做。

解决方案:

显然,我不能/不应该在checkbox元素之前删除隐藏元素。所以这是我的jQuery代码,用于隐藏所有隐藏的表单元素在页面上显示:

//fix zf hidden element from displaying
$('input[type=hidden]').filter(function() {
    var noLabel = $(this).closest('dd').prev('dt').html() === '&nbsp;';
    var onlyChild = $(this).is(':only-child');
    if (noLabel && onlyChild) {
        return true;
    }
    return false;
}).each(function() {
    $(this).closest('dd').hide()
           .prev('dt').hide();
});

6 个答案:

答案 0 :(得分:5)

要更改表单元素的呈现方式,可以使用decorators,可以使用

进行修改
// Overwrite existing decorators with this single one:
$element->setDecorators(array('Composite'));

有关所有默认装饰器的列表,请查看standard decorators;对于表单字段使用的装饰器列表,您可以看到standard form elements

在我看来,隐藏的表单元素是从Zend中添加的,具有精确的目的,删除它(如果可能的话)可能会导致一些问题。我的第一个想法是,Zend使用隐藏的形式来检查值是否已经改变,或者验证是否真的是从Zend生成的(这个假设似乎不那么合理)。

答案 1 :(得分:5)

主题真的很旧,但几天前我发现了类似的问题 - 我通过javascript动态创建表单 - 点击(+)在显示的表单中添加一行(一个隐藏的输入,两个复选框和两个选择)。 / p>

我发现,当我向服务器发送_POST时,并不会发送内核 - 默认的隐藏零被发送,而不是选中的复选框。解决方案是将复选框设置为数组:

$c = new Zend_Form_Element_Checkbox( 'check1' );
$c->setIsArray( true );

在这种情况下,不会渲染其他隐藏输入。

PS。抱歉我的英文;)

答案 2 :(得分:1)

Andrew,这是如何真正隐藏隐藏的表单元素:

$element1 = $form->createElement('hidden', 'element1');
$element1
  ->setDecorators(array(
    'ViewHelper',
    array('HtmlTag', array('tag' => 'dd'))
  ));

现在,您不必乱用jQuery代码来尝试缩小它们。而且,您也不必担心隐藏的复选框字段。

答案 3 :(得分:1)

我自己只是遇到了隐藏元素的复选框。我没有该帖子的解决方案,但想添加我对隐藏字段的想法。如果用户没有选中该框,则仍然会传递值0。否则,不会发布复选框。

答案 4 :(得分:1)

线程陈旧但没有答案是正确的......

我有同样的问题,但我已经弄明白了,所以这是正确答案:

如果您不喜欢在取消选中时发布的复选框值,并且仅在选中时发送了一些值 - 只需使用此代码:

$chk = new Zend_Form_Element_Checkbox('test_checkbox');
$chk->setRequired();
$chk->setUncheckedValue(null);
$chk->setCheckedValue(1);
...

选中的值是'some_value',但是当取消选中复选框时,该值为null,因此它不会验证,因为设置了'required'。它现在适用于我,并且不需要使用“复杂的”jquery脚本来删除隐藏的字段等。

答案 5 :(得分:1)

您可以向复选框表单元素添加属性disableHidden,以防止它在呈现时添加隐藏字段。

$chk = new Zend_Form_Element_Checkbox('test_checkbox');
$chk->setAttrib('disableHidden', true);