Yii - GridView 小部件


GridView 小部件从数据提供者获取数据并以表格的形式呈现数据。表的每一行代表一个数据项,一列代表该项目的一个属性。

步骤 1 - 以这种方式修改数据小部件视图。

<?php
   use yii\grid\GridView;
   echo GridView::widget([
      'dataProvider' => $dataProvider,
   ]);
?>

步骤 2 - 转到http://localhost:8080/index.php?r=site/data-widget,您将看到 DataGrid 小部件的典型用法。

数据网格小部件

DataGrid 小部件的列是根据yii\grid\Column类配置的。它代表模型属性,可以进行过滤和排序。

步骤 3 - 要将自定义列添加到网格中,请以这种方式修改数据小部件视图。

<?php
   yii\grid\GridView;
   echo GridView::widget([
      'dataProvider' => $dataProvider,
      'columns' => [
         'id',
         [
            'class' => 'yii\grid\DataColumn', // can be omitted, as it is the default
            'label' => 'Name and email',
            'value' => function ($data) {
               return $data->name . " writes from " . $data->email;
            },
         ],
      ],
   ]);
?>

步骤 4 - 如果您访问地址http://localhost:8080/index.php?r=site/data-widget,您将看到如下图所示的输出。

数据网格视图

可以使用不同的列类来自定义网格列,例如 yii\grid\SerialColumn、yii\grid\ActionColumn 和 yii\grid\CheckboxColumn。

步骤 5 -按以下方式修改数据小部件视图。

<?php
   use yii\grid\GridView;
   echo GridView::widget([
      'dataProvider' => $dataProvider,
      'columns' => [
         ['class' => 'yii\grid\SerialColumn'], 'name',
         ['class' => 'yii\grid\ActionColumn'],
         ['class' => 'yii\grid\CheckboxColumn'],
      ],
   ]);
?>

步骤 6 - 转到http://localhost:8080/index.php?r=site/data-widget,您将看到以下内容。

修改后的 DataGrid 视图