我想在表单中添加一个简单的复选框:
$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"> </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中标签为
的所有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() === ' ';
var onlyChild = $(this).is(':only-child');
if (noLabel && onlyChild) {
return true;
}
return false;
}).each(function() {
$(this).closest('dd').hide()
.prev('dt').hide();
});
答案 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);