0

我有下表:

CREATE TABLE "place" (
    "id" int8 NOT NULL DEFAULT nextval('place_id_seq'::regclass),
    "name" varchar(128) NOT NULL,
    "parent" int8,
    "description" varchar(100)
)
WITH (OIDS=FALSE);

(这是 PostgreSQL,但这在这里不应该相关)

我通过 giix 创建了 CRUD,并更改了一些关系以满足我的需要。所以我最终得到:

public function relations() {
    return array(
        'parent0' => array(self::BELONGS_TO, 'Places', 'parent'),
        'places' => array(self::HAS_MANY, 'Places', 'parent'),
    );
}

这里的目标是一个地方可以属于另一个地方并且有多个子地方。

我的问题是我需要更改管理操作以匹配以下网格: 检查员操纵的打印以反映所需的行为

检查员操纵的打印以反映所需的行为

所以我的问题是获取所有子对象的列表并将其显示为链接列表。我尝试将相应的 admin.php 视图文件更改为:

$this->widget('zii.widgets.grid.CGridView', array(
    'id' => 'places-grid',
    'dataProvider' => new CActiveDataProvider('Places', array('id'=>$model->places)),
    'filter' => $model,
    'columns' => array(
        array(
                'name'=>'parent',
                'value'=>'GxHtml::valueEx($data->parent0)',
                'filter'=>GxHtml::listDataEx(Places::model()->findAllAttributes(null, true)),
                ),
        'name',
        'places',
        array(
            'class' => 'CButtonColumn',
        ),
    ),
));

但是,正如预期的那样,这会通过一个错误:

htmlspecialchars() 期望参数 1 是字符串,给定数组

另外我不知道这甚至可以与内置的高级搜索一起使用。

任何人都可以在这里指出我正确的方向吗?

4

1 回答 1

1

经过大量搜索,我找到了解决问题的方法。不确定这是否是最好的方法,但效果很好:

$this->widget('zii.widgets.grid.CGridView', array(
    'id' => 'places-grid',
    'dataProvider' => new CActiveDataProvider('Places', array('id'=>$model->places)),
    'filter' => $model,
    'columns' => array(
        array(
                'name'=>'parent',
                'value'=>'GxHtml::valueEx($data->parent0)',
                'filter'=>GxHtml::listDataEx(Places::model()->findAllAttributes(null, true)),
                ),
        'name',
        array(
        'header'=>'Children',
        'type'=>'html',
                'value'=> function($data) {
                    $placesLinks = array();
                    foreach ($data->places as $place) {
                        $placesLinks[] = GxHtml::link(GxHtml::encode(GxHtml::valueEx($place, 'name')), array('places/view', 'id' => GxActiveRecord::extractPkValue($place, true)));
                    }
                    return implode(', ', $placesLinks);
                }
        ),
        array(
            'class' => 'CButtonColumn',
        ),
    ),
));

这使用 Giix。如果您不使用它,那么您将不得不相应地更改链接生成。

干杯

于 2012-12-14T06:48:32.090 回答