我有一个名为table的表,它有id
和name
作为属性。
对于表中的每个条目,我希望生成一个复选框。
我该怎么做?
我正在使用Yii Boostrap插件,我希望我需要使用这样的东西:
foreach(...)
echo $form->checkBoxRow($model, 'name');
这是我从Yii引导程序文档中得到的。
试试这个简单的
在这种情况下,预检查只需将数组作为第二个参数即可工作如下所示
<?$select=array('2','3');?>
<?php echo CHtml::checkBoxList(
'TableValues',
'$select',//you can pass the array here which you want to be pre checked
CHtml::listData(Table::model()->findAll(),'id','name'),
array('checkAll'=>'Select all tasks', 'checkAllLast'=>true)
); ?>
您可以使用在控制器中获取选定的复选框值
print_r($_POST['TableValues']);
更新
为此,预检查工作u必须将数组分配给如下所示的模型属性
<?php $model->modelAttributename=array('3','5')//respective checked values as of yours
<?php echo $form->checkBoxList(
$model,
'modelAttributename',
CHtml::listData(Table::model()->findAll(),'id','name'),
array('checkAll'=>'Select all tasks', 'checkAllLast'=>true)
); ?>
您应该从sql查询中看到您的结果数组,并了解如何从结果数组中访问您想要的任何字符串,然后创建包含名称列表的字符串数组。例如,您的结果查询是$result["name"]=数组("a"、"b"、"c");
<?php /** @var BootActiveForm $form */
$form = $this->beginWidget('bootstrap.widgets.TbActiveForm', array(
'id'=>'horizontalForm',
'type'=>'horizontal',
));
?>
<fieldset>
<legend>Legend</legend>
<?php
$result["name"] = array("a","b","c");
echo $form->checkBoxListRow($model, 'checkboxes', $result["name"]);
?>
</fieldset>
检查此示例:
图书型号:
'authors' => array(self::MANY_MANY, 'Author', 'authorbook(book_id,author_id)'),
作者型号:
'books' => array(self::MANY_MANY, 'Book', 'authorbook(author_id, book_id)'),
复选框列表格式:
$books = CHtml::listData(Book::model()->findAll(), 'id', 'name');
$selected_keys = array_keys(CHtml::listData( $model->books, 'id' , 'id'));
echo CHtml::checkBoxList('Author[books][]', $selected_keys, $books);