我有一个包含多个模型的表单。 1个模型将显示1个记录,其他模型将以表格格式显示多个记录。当我提交保存时,我只获得每个模型的最后一条记录。我如何获得模型的所有记录?
以下是我如何在表单
上呈现表格格式模型的示例 // lines tab
$lineListContent = "<div id='form_line_list'>
<table>
<tr>
<th>JOBNO</th>
<th>NAME</th>
<th>SEQ</th>
<th>DATEIN</th>
<th>DATEDONE</th>
<th>STATUS</th>
<th>PCENthONE</th>
<th>EARNED</th>
<th>VALUE</th>
<th>COMMENTS</th>
<th>SENTBACK</th>
<th>DATEDUE</th>
<th>ORIGTAPES</th>
</tr>
";
$lineListContentRows = null;
foreach ($jobs as $i=>$item){
$lineListContentRows = $lineListContentRows . $this->renderPartial('/jobs/_form', array('model'=>$item,'form'=>$form),TRUE);
}
$lineListContent = $lineListContent . $lineListContentRows . "
</table></div>";
for循环抓取其模型的输入字段
_form
<?php
/* @var $this JobsController */
/* @var $model Jobs */
/* @var $form CActiveForm */
?>
<div class="form">
<tr>
<td><?php echo $form->textField($model,'JOBNO'); ?></td>
<td><?php echo $form->textField($model,'NAME'); ?></td>
<td><?php echo $form->textField($model,'SEQ'); ?></td>
<td><?php echo $form->textField($model,'DATEIN'); ?></td>
<td><?php echo $form->textField($model,'DATEDONE'); ?></td>
<td><?php echo $form->textField($model,'STATUS'); ?></td>
<td><?php echo $form->textField($model,'PCENTDONE'); ?></td>
<td><?php echo $form->textField($model,'EARNED'); ?></td>
<td><?php echo $form->textField($model,'VALUE'); ?></td>
<td><?php echo $form->textField($model,'COMMENTS'); ?></td>
<td><?php echo $form->textField($model,'SENTBACK'); ?></td>
<td><?php echo $form->textField($model,'DATEDUE'); ?></td>
<td><?php echo $form->textField($model,'ORIGTAPES'); ?></td>
</tr>
</div><!-- form -->
答案 0 :(得分:1)
如果要保存表格数据,则必须在属性前加上括号中的数字。所以
foreach ($jobs as $i=>$item){
$lineListContentRows = $lineListContentRows . $this->renderPartial('/jobs/_form', array('model'=>$item,'form'=>$form,'i'=>$i),TRUE);
}
并在_form.php
中将每个textField
的第二个参数更改为
<td><?php echo $form->textField($model,"[$i]JOBNO"); ?></td>// remember use double quotes
如果您进行上述更改,则$_POST['modelName']
将包含数据作为数组。通过forloop
迭代它并保存每个项目。有关详细信息,请查看official documentation.