基于 Yii(关系)数据库表动态创建 html 表


Creating a html table dynamically based on Yii (relations)database table?

我正在尝试创建"视图"或一个函数,该函数将通过给定表中的列和表数据本身来构建HTML表。这将是一个由 Yii 中的 renderPartial 方法调用的页面。我想象这样做(将使用伪代码演示(:

    void view(array $cols, array $tabledata) 
    {
    //$tabledata will be an array of CActiveRecord objects. $cols is an array of strings from getColumnNames().
    <table><thead><tr>
    foreach($cols as $col)
    {
        <th>$col</th>
    }
    </tr></thead><tbody>
    foreach($tabledata as $data)
    {
        <tr>
        foreach($cols as $col)
        {
            <td>$data->$col</td>
        }
        </tr>
    }
    </tbody></table>
    }

但是我遇到的问题是我无法获得关系的列。我找到了 http://www.yiiframework.com/doc/api/1.1/CDbTableSchema,但这似乎只为您提供特定表的列名。我需要一种方法来获取使用关系生成 HTML 表时使用的所有列。或者,如果有人有更好的方法来做到这一点,请告诉我。谢谢!

编辑:请注意,我没有使用CGridView(包括我在下面列出的那个(的原因是我不想知道列是什么或数据。我希望能够仅使用代码构建表。

没有必要创建这样的函数。CGridView就是你正在寻找的。它将数据呈现为 html 表。下面是一个示例代码。

<?php $this->widget('zii.widgets.grid.CGridView', array(
        'dataProvider' => new CArrayDataProvider($tabledata),
        'columns' => array(
         //specify the colums you wanted here
        ),
    ));
?>

对于其他任何想要学习如何做到这一点的人来说,这就是我想出解决方案的方式:

--Model--
//Attributes:
$name;
$age;
$data;
--Controller--
//Controller stuff
public function actionShow()
{
  $this->render('show',array('model'=>loadModel(1)));
}
--view--
//traditonal way
echo CHtml::encode($model->getAttributeLabel('name');
echo CHtml::encode($model->name);
echo CHtml::encode($model->getAttributeLabel('age');
echo CHtml::encode($model->age);
echo CHtml::encode($model->getAttributeLabel('data');
echo CHtml::encode($model->data);
//one function way
foreach ($model->attributes as $col=>$val)
{
  CHtml::encode($model->getAttributeLabel($col);
  CHtml::encode($val);
}

这就是我想要的,以防其他人想尝试。