1

我需要每个元素后带有工具提示的 radioButtonList。

我使用这段代码:

<?php echo $form->radioButtonList($model, 'Field', CHtml::listData(FieldDataModel::model()->findAll(), 'id', 'name')); ?>

并得到以下结果:

[x] ParamName0
[ ] ParamName1
[ ] ParamName2

我怎样才能得到这样的结果:

[x] ParamName0 [?]-(Link, that shows description. Description is taking from FieldDataModel)
[ ] ParamName1 [?]
[ ] ParamName2 [?]

可能是,像 'template' => '{input} {label}' 这样的模板可以帮助我吗?

4

2 回答 2

1

这在当前的实现中是不可能的。您必须遍历列表数据并使用CHtml::radioButton()或手动创建按钮CHtml::activeRadioButton()

于 2013-04-09T15:32:33.930 回答
0

作为替代解决方案,您仍然可以CActiveForm动态使用和创建带有描述的所需链接。例如,它可能看起来像这样:

<?php
$listModels = FieldDataModel::model()->findAll();
$form = $this->beginWidget('CActiveForm');
?>
<div>
<?php
echo $form->radioButtonList($model, 'Field', CHtml::listData($listModels, 'id', 'name'));
?>
</div>
<?php
$this->endWidget();

$descriptions = array();
foreach ($listModels as $listModel)
    $descriptions['id-' . $listModel->id] = $listModel->description;
$modelClassName = get_class($model);
Yii::app()->clientScript->registerScript("customRadioButtonListInit", "
    var descriptions = " . CJavaScript::encode($descriptions) . ";
    jQuery('#" . $modelClassName . "_Field input[type=\"radio\"]').each(function() {
        var valueAttr = jQuery(this).attr('value');
        var jqLabel = jQuery(this).next('label');
        var jqTooltipLink = jQuery('<a></a>')
            .text('?')
            .attr('title', descriptions['id-' + valueAttr])
            .click(function(event) {
                event.preventDefault();
                event.stopPropagation();
                // TODO: implement your tooltip here...
                alert(jQuery(this).attr('title'));
            });
        jqLabel.after(jqTooltipLink).after(' ');
    })
", CClientScript::POS_READY);
于 2013-04-09T16:14:43.000 回答