yii多模型的多形式多记录

时间:2013-02-08 10:12:42

标签: php linux forms yii

我有一个包含多个模型的表单。 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 -->

1 个答案:

答案 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.