如何在yii2中从不同的模型创建视图?

时间:2015-09-02 10:15:16

标签: php yii2

我是yii的新手。我正在开发客户项目应用程序。我有一个视图,其中iam显示来自模型,客户和项目的数据。

如何创建表单以添加新项目? my project is here

要在客户视图中显示项目数据,请使用

$query=Projects::find()
    ->where(['projects_clients_id'=> $model->customer_id]);    

       $dataProvider = new ActiveDataProvider([
        'query' => $query,        
        'pagination' => [
            'pageSize' => 20,
        ],
    ]);
    echo GridView::widget([
        'dataProvider' => $dataProvider,
    ]);

2 个答案:

答案 0 :(得分:6)

您可以在视图中呈现多个模型和/或dataProvider (正确构造)

例如:

    return $this->render('viewTestMulti', [
        'modelOne'                 =>$modelOne,
        'dataProviderTwo'                => $providerTwo,
        'dataProviderThree'      => $providerThree,
        'modeFour'                    => $modelFour,
    ]);

然后你可以使用一个带有几个与正确的dataProvider相关的gridView的视图,并且几个表单中的每个人都有适当的操作 因此,当您按下指定的提交时,您将调用正确的控制器操作

<?php
    use yii\helpers\Html;
    use yii\widgets\ActiveForm;
?>


<?php $formOne = ActiveForm::begin(); 
      $formOne->action=  yii\helpers\Url::to('ControllerOne\create');
 ?>

<?= $formOne->field($modelOne, 'name') ?>

<?= $formOne->field($modelOne, 'email') ?>

<div class="form-group">
   <?= Html::submitButton('Submit', ['class' => 'btn btn-primary']) ?>
</div>
<?php ActiveForm::end(); ?>



<?php $formFour = ActiveForm::begin(); 
   $formFour->action= yii\helpers\Url::to('ControllerFour\create');
?>

<?= $formFour->field($modelFour, 'name_four') ?>

<?= $formFour->field($modelFour, 'email_four') ?>

<div class="form-group">
   <?= Html::submitButton('Submit', ['class' => 'btn btn-primary']) ?>
</div>
<?php ActiveForm::end(); ?>

我希望这可能有用

答案 1 :(得分:1)

您拥有关于ActiveForms的所有文档,如果您是Yii2的新用户,我建议使用The Definitive Guide to Yii 2.0here表单部分

这是一个基本形式:

<?php
   use yii\helpers\Html;
   use yii\widgets\ActiveForm;
?>
<?php $form = ActiveForm::begin(); ?>

<?= $form->field($model, 'name') ?>

<?= $form->field($model, 'email') ?>

<div class="form-group">
    <?= Html::submitButton('Submit', ['class' => 'btn btn-primary']) ?>
</div>