如何在更新控制器中加载多个模型


How to load multiple models in update controller

在_form.php文件中,我有来自两个不同模型的文本框,我对create控制器进行了更改,以插入两个模型的记录,但问题是在update控制器中,如何将第二个模型的数据加载到第二个模型的文本框中
只有与第一个模型相关的文本框才会被填充。

只需将两个模型渲染到控制器中的update视图即可。

$this->render('update', array(
    'model1' => $model1,
    'model2' => $model2,
));

在你的_form.php中调用类似的文本框

<?php echo $form->labelEx($model1, ‘data1’); ?>
<?php echo $form->textField($model1, ‘data1’, array(‘size’ => 60, ‘maxlength’ => 250)); ?>
<?php echo $form->labelEx($model2, ‘data2’); ?>
<?php echo $form->textField($model2, ‘data2’, array(‘size’ => 60, ‘maxlength’ => 250)); ?>

希望这能有所帮助。

编辑

由于create视图可能使用相同的_form.php页面,因此需要创建另一个_form.php文件,如_formUpdate.php[_form.php的副本]页面,并从update.php调用render _formUpdatephp而非_form.php,并进行上述更改

_form

    <div class="form">
<?php $form=$this->beginWidget('CActiveForm', array(
    'id'=>'tabel1-form',
    'enableAjaxValidation'=>false,
)); ?>
    <p class="note">Fields with <span class="required">*</span> are required.</p>
    <?php echo $form->errorSummary($model); ?>
    <div class="row">
        <?php echo $form->labelEx($model,'name'); ?>
        <?php echo $form->textField($model,'name',array('size'=>44,'maxlength'=>44)); ?>
        <?php echo $form->error($model,'name'); ?>
    </div>
    <div class="row">
        <?php echo $form->labelEx(Table2::model(),'address'); ?>
        <?php echo $form->textField(Table2::model(),'address',array('size'=>44,'maxlength'=>44)); ?>
        <?php echo $form->error(Table2::model(),'address'); ?>
    </div>
    <div class="row buttons">
        <?php echo CHtml::submitButton($model->isNewRecord ? 'Create' : 'Save'); ?>
    </div>
<?php $this->endWidget(); ?>
</div><!-- form -->

update.php

    <?php
$this->breadcrumbs=array(
    'Tabel1s'=>array('index'),
    $model->name=>array('view','id'=>$model->id),
    'Update',
);
$this->menu=array(
    array('label'=>'List Tabel1', 'url'=>array('index')),
    array('label'=>'Create Tabel1', 'url'=>array('create')),
    array('label'=>'View Tabel1', 'url'=>array('view', 'id'=>$model->id)),
    array('label'=>'Manage Tabel1', 'url'=>array('admin')),
);
?>
<h1>Update Tabel1 <?php echo $model->id; ?></h1>
<?php echo $this->renderPartial('_formUpdate', array('model'=>$model,'model2'=>$model2)); ?>

表格1控制器.php

 public function actionCreate()
    {
        $model=new Tabel1;
    $model2=new Table2;
        // Uncomment the following line if AJAX validation is needed
        // $this->performAjaxValidation($model);
        if(isset($_POST['Tabel1'])&&isset($_POST['Table2']))
        {
            $model->attributes=$_POST['Tabel1'];
                        $model2->attributes=$_POST['Table2'];
            if($model->save()&&$model2->save())
                $this->redirect(array('view','id'=>$model->id));
        }
        $this->render('create',array(
            'model'=>$model,
                    'model2'=>$model2
        ));
    }
    /**
     * Updates a particular model.
     * If update is successful, the browser will be redirected to the 'view' page.
     * @param integer $id the ID of the model to be updated
     */
    public function actionUpdate($id)
    {
        $model=$this->loadModel($id);
    $model2=$this->loadModel2($id);
        // Uncomment the following line if AJAX validation is needed
        // $this->performAjaxValidation($model);
//echo $model2->address;
        if(isset($_POST['Tabel1'])&&isset($_POST['Table2']))
        {
            $model->attributes=$_POST['Tabel1'];
                        $model2->attributes=$_POST['Table2'];
            if($model->save()&&$model2->save())
                $this->redirect(array('view','id'=>$model->id));
        }
        $this->render('update',array(
            'model'=>$model,
                    'model2'=>$model2
        ));
    }
 public function loadModel2($id)
    {
        $model=Table2::model()->findByPk(1);
        if($model===null)
            throw new CHttpException(404,'The requested page does not exist.');
        return $model;
    }