YII CListView如何将id添加到itemwrapper


YII CListView How to add id to itemwrapper

在CListView中有一个名为"itemsCssClass"的属性,它基本上将HTML类属性添加到Itemwrapper中。

如果我想添加一个ID或任何其他htmlOptions,我将如何在包装器上完成它呢。。?

我的代码是:

    <?php $this->widget('zii.widgets.CListView', array(
    'dataProvider'=>$model->search(),
    'viewData'=>array('x'=>''),
    'itemView'=>'_classifieds',
    'id'=>'boa_ads',
    'itemsCssClass'=>'test'
));

此代码将生成以下HTML:

<div id="boa_ads" class="list-view">
 <div class="summary">Displaying 1-4 of 4 results.</div>
   <div class="items"><!-- HERE ID LIKE TO ADD AN ID-->
     ----ITEMS GOES HERE ----
   </div>
 </div>
</div>

感谢您提前提供的帮助

来自Yii的来源:

public function renderItems()
    {
            echo CHtml::openTag($this->itemsTagName,array('class'=>$this->itemsCssClass))."'n";
             .....
            echo CHtml::closeTag($this->itemsTagName);
    }

我只是看到class属性被传递给itemsTagName,所以你可能需要扩展CListView才能做到这一点

您可以创建一个CCustomListView类(在application/widgets文件夹内),该类从CListView扩展并覆盖renderItems()函数例如:

<?php
Yii::import("zii.widgets.CListView");
class CCustomListView extends CListView
{
    public $itemsHtmlOptions;
    /**
     * Renders the data item list.
     */
    public function renderItems()
    {
        echo CHtml::openTag($this->itemsTagName, array_merge(array('class'=>$this->itemsCssClass), $this->itemsHtmlOptions))."'n";
        $data=$this->dataProvider->getData();
        if(($n=count($data))>0)
        {
            $owner=$this->getOwner();
            $viewFile=$owner->getViewFile($this->itemView);
            $j=0;
            foreach($data as $i=>$item)
            {
                $data=$this->viewData;
                $data['index']=$i;
                $data['data']=$item;
                $data['widget']=$this;
                $owner->renderFile($viewFile,$data);
                if($j++ < $n-1)
                    echo $this->separator;
            }
        }
        else
            $this->renderEmptyText();
        echo CHtml::closeTag($this->itemsTagName);
    }
}

在你看来,你可以像这样使用它:

<?php $this->widget('application.widgets.CCustomListView', array(
    'dataProvider'=> 'your_data_provider',
    'itemsHtmlOptions' => array('style' => 'color:blue', 'id' => 'your_id'),
    'itemView'=>'your_item_view',
    'template'=>'your_template',
)); ?>

因此itemsHtmlOptions中的样式将应用于listview

这个链接对你也很有用:如何扩展CListView以删除额外的yii添加的标记?