Yii - GridView 组件



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

步骤 1 − 修改datawidget视图。

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

步骤 2 − 访问https://127.0.0.1:8080/index.php?r=site/data-widget,您将看到 DataGrid 组件的典型用法。

DataGrid widget

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

步骤 3 − 要向网格添加自定义列,请按以下方式修改datawidget视图。

<?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 − 如果您访问地址https://127.0.0.1:8080/index.php?r=site/data-widget,您将看到如下所示的输出。

DataGrid view

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

步骤 5 − 按以下方式修改datawidget视图。

<?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 − 访问https://127.0.0.1:8080/index.php?r=site/data-widget,您将看到以下内容。

Modified DataGrid view
广告