我有一个带有单选按钮的表单:
$this->add([
'name' => 'time',
'options' => [
'value_options' => [
'0' => '9:00 - 12:00',
'1' => '12:00 - 16:00',
'2' => '16:00 - 19:00',
],
'label_attributes' => [
'class' => 'WW_OBJ_fm-label',
]
],
'type' => 'Radio'
]);
在视图中,我输出如下:
<div>
<?php echo $this->formElement($form->get('time')); ?>
</div>
并获得输出(为可读性格式化):
<div>
<label class="WW_OBJ_fm-label">
<input type="radio" name="time" value="0"/>
9:00 - 12:00
</label>
<label class="WW_OBJ_fm-label">
<input type="radio" name="time" value="1"/>
12:00 - 16:00
</label>
<label class="WW_OBJ_fm-label">
<input type="radio" name="time" value="2"/>
16:00 - 19:00
</label>
</div>
但我需要,标签文本由<span>
:包装
<div>
<label class="WW_OBJ_fm-label">
<input type="radio" name="time" value="0"/>
<span class="WW_label-text">9:00 - 12:00</span>
</label>
<label class="WW_OBJ_fm-label">
<input type="radio" name="time" value="1"/>
<span class="WW_label-text">12:00 - 16:00</span>
</label>
<label class="WW_OBJ_fm-label">
<input type="radio" name="time" value="2"/>
<span class="WW_label-text">16:00 - 19:00</span>
</label>
</div>
实现这一目标的最佳方式是什么?
我为您的问题找到了三种可能的解决方案。
1) 扩展Zend'Form'View'Helper'FormRadio
类,覆盖renderOptions
方法,几乎完全复制在Zend'Form'View'Helper'FormMultiCheckbox
中可以找到的方法,但可能会添加一个选项,将可选属性传递给span
元素
2) 非常微妙,但可以节省您编写一些代码:使用翻译器。由于单选值选项被转换,您可以在配置中保留您的值,但在交易中添加span
元素
3) 不要使用$this->formElement
来显示元素,而是实际编写所有的html
解决方案是使用labelOption"disable_html_escape":
$this->add([
'name' => 'time',
'options' => [
'value_options' => [
'0' => '<span class="WW_label-text">9:00 - 12:00</span>',
'1' => '<span class="WW_label-text">12:00 - 16:00</span>',
'2' => '<span class="WW_label-text">16:00 - 19:00</span>',
],
'label_attributes' => [
'class' => 'WW_OBJ_fm-label',
]
],
'type' => 'Radio'
]);
$element = $this->get('time');
$element->setLabelOptions(['disable_html_escape' => true]);