2

谁能给我示例,说明如何在不使用 Widget 的情况下从模型中检索数据?因为需要获取每个表列的数据并将它们放在我自己的视图中(不使用小部件)

控制器 :

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

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

看法 :

<?= GridView::widget([
        'dataProvider' => $dataProvider,
        'filterModel' => $searchModel,
        'columns' => [
        ['class' => 'yii\grid\SerialColumn'],
        'id',
            'sku',
            'name',
            'short_description',
            'long_description',
            'thumb_img:ntext',
            'large_img:ntext',
            'url_content:ntext',
             'contact_info',
             'status',
            'currency',
             'price',
            'dimension',
            'weight',
            // 'created',
            // 'modified',

            ['class' => 'yii\grid\ActionColumn'],
        ],
    ]); ?>

上面的小部件遍历预定义的gridview中的元素,但我想做的是:

foreach($data as $ab) {
   echo $ab->id;
}
4

2 回答 2

3

你可以这样做:

/* assuming $data is an ActiveDataProvider object */
$models = $data->getModels(); 

foreach($models as $model) { ... }

在这里查看更多

于 2015-04-16T15:59:53.727 回答
2

如果您使用的是ActiveDataProvider:控制器:

public function actionMyAction()
{
    $dataProvider = new ActiveDataProvider([
        'query' => MyModel::find(),
    ]);

    return $this->render('my-results-page', [
        'dataProvider' => $dataProvider,
    ]);
}

看法:

 <?php
  foreach ($dataProvider->models as $model){
            echo $model->myProperty;
        }  
 ?>

如果您使用的是查询,例如:

    $query = (new \yii\db\Query())
        ->select('this, that')
        ->from('over_there');
    $command = $query->createCommand();
    $rows = $command->queryAll();

然后你可以像这样迭代结果(假设你在一个名为 $dataProvider 的变量中将它传递给视图):

  foreach($dataProvider as $data)
  {            
   $data['myProperty'];
  }
于 2015-04-16T23:07:26.650 回答