Yii2:如何在Yii2中显示没有gridview的搜索结果

时间:2015-07-18 13:51:00

标签: php search gridview yii2

尝试为我的页面实现搜索框,用户必须输入job_code才能获得订单状态。我得到了结果,但这个结果在网格视图中我不想要这个网格视图。所以,我可以在页面上的不同位置放置各种属性。

搜索表单用户必须输入job_code

<?php $form = ActiveForm::begin(['action' => ['tracking'],'method' => 'get','class'=>'lockscreen-credentials']); ?>
<?= $form->field($searchModel, 'job_code')->textInput(array('placeholder' => 'Job Code..'))->label(false); ?>
<?= Html::submitButton('Search', ['class' => 'btn btn-primary btn-block btn-flat']) ?>
<?= Html::resetButton('Reset', ['class' => 'btn btn-primary btn-block btn-flat']) ?> 
<?php ActiveForm::end(); ?>

enter image description here

将显示搜索结果的结果页面

<body class="lockscreen">
<?= GridView::widget([
        'dataProvider' => $dataProvider,
        'filterModel' => $searchModel,
        'columns' => [
            'job_code',
            'client_code',
            'company_name',
            'job_description:ntext',
            'status',
            'emp_email:email',
            'emp_mobile',
            'emp_first_name',
            'emp_last_name',  
        ],
    ]); ?>      
</body>

enter image description here

控制器

public function actionIndex()
    {
        $model = new Status();
        $searchModel = new StatusSearch();
        $dataProvider = $searchModel->search(Yii::$app->request->queryParams);

        return $this->render('index', [
            'searchModel' => $searchModel,
            'dataProvider' => $dataProvider,
            'model' => $model,
        ]);
    }

    public function actionTracking()
    {
         $model = new Status();
         $searchModel = new StatusSearch();
         $dataProvider = $searchModel->search(Yii::$app->request->queryParams);

        return $this->render('tracking', [
            'searchModel' => $searchModel,
            'dataProvider' => $dataProvider,
            'model' => $model,
        ]);
    }

如何实现这一目标?

1 个答案:

答案 0 :(得分:1)

您可以通过这种方式访问​​数据提供者模型数据

对于转储结果,您不需要使用html格式化代码,并将视图限制为可用的第一(或唯一)数据行。 然后,对于我使用的样本,仅使用echo

<body class="lockscreen">
   <?php 

     echo 'job_code = ' . $dataProvider->models[0]->job_code .' - ' ;
     echo 'client_code = ' . $dataProvider->models[0]->client_code .' - ';
     echo 'company_name = ' .  $dataProvider->models[0]->company_name .' - ';
     echo 'job_description = ' . $dataProvider->models[0]->job_description .' - ';
     echo 'status = ' . $dataProvider->models[0]->status .' - ';
     // and so on  



</body>

我需要显示更多的一行数据,显然必须循环所有您喜欢的模型