我是Yii框架的新手,不能用下拉列表解决这个问题。
在我的页面中,我有两个下拉列表,它们都是多选下拉列表。第二个取决于第一个下拉列表。例如,
1-下降是水果、蔬菜、饮料;
2-下拉列表取决于用户的选择,如果用户选择水果和饮料,则应显示苹果、葡萄、果汁、啤酒(全部放在一个下拉列表中);
如果用户只选择一个选项,例如第一个下拉列表中的蔬菜,第二个应该显示洋葱、土豆等。
这里的源代码:
//---------- VIEW ------------
<div id="left">
<div class="btn-group">
<?php
echo CHtml::dropDownList('group', '', CHtml::listData($group,'group','group'), array(
'multiple'=>'multiple',
'ajax'=>array(
'type' => 'POST',
'url' => CController::createUrl('site/change'),
'update' => '#e5'
),
'id' => 'e4',
'style' => 'width:300px'
));
?>
</div>
</div>
<div id="right">
<div class="btn-group">
<?php
echo CHtml::dropDownList('subgroup','', array(), array(
'multiple' => 'multiple',
'id'=>'e5',
'style' => 'width:300px'
));
?>
</div>
</div>
// ------------ CONTROLLER ------------
public function actionChange()
{
$groupName = $_POST['group'];
$dpCriteria = new CDbCriteria();
$dpCriteria->select = 'subgroups';
$dpCriteria->condition = 'group = '.$groupName;
$data = Subgroups::model()->findAll($dpCriteria);
$data = CHtml::listData($data,'subgroups','subgroups');
foreach($data as $value=>$name)
{
echo CHtml::tag('option',
array('value'=>$value),CHtml::encode($name),true);
}
}
您询问的方法是Dependent Dropdown
。YII框架有创建Dependent Dropdown
的教程。查看此链接了解更多详细信息和示例
编辑:
在您的代码中,您正在检查具有单个值'group = '.$groupName;
的groupname。但$groupname
是一个值数组。因此,您已经在mysql中使用了in
和内爆$groupname数组的值。
您的条件是:
$dpCriteria->condition='group in('.intercontide(",",$groupName).')';
这样试试。在您的ajax阵列中,
'update'=>'#'.CHtml::activeId($model,'attribute_to_update'),
'data'=>array('atribute'=>'js:this.value'),