Yii視圖操作之自定義分頁實現(xiàn)方法

字號:


    本文實例講述了Yii視圖操作之自定義分頁實現(xiàn)方法。分享給大家供大家參考,具體如下:
    1. 視圖文件調(diào)用cgridview,clistview時候調(diào)用自定義的分頁方法
    <?php $this->widget('zii.widgets.grid.CGridView', array(
     'id'=>'news-grid',
     'dataProvider'=>$model->search(),
     'filter'=>$model,
     'template'=>'{items}{summary}{pager}',
      'selectableRows'=>2,
      'pager'=>'ZPager',
      'summaryText'=>'頁數(shù):{pages}/{page}頁',
      'columns'=>array(
      array(
       'class'=>'CCheckBoxColumn',
       'footer'=>'<button onclink="deleteAll()">button</button>
          <button onclink="refashAll()">button</button>',
       'footerHtmlOptions'=>array('colspan'=>5),
       'selectableRows'=>2,
      ),
      'id',
      array('name'=>'title',
        'htmlOptions'=>array('width'=>'20%'),
        'value'=>'mb_substr($data->title,0,10,"utf-8")',
       ),
      array('name'=>'content',
        'htmlOptions'=>array('width'=>'20%'),
        'value'=>'mb_substr(strip_tags($data->content),0,10,"utf-8")',
       ),
      array('name'=>'type',
        'value'=>'News::model()->getNewsType($data->type)',
       ),
      'user',
      array('name'=>'status',
        'value'=>'News::model()->getNewsStatus($data->status)',
        ),
      array(
       'class'=>'CButtonColumn',
       'buttons'=>array(
        'view'=>array('visible'=>'false'),
        //'delete'=>array('click'=>'true'),
       ),
      ),
     ),
    ));
    2. 復(fù)制基類分頁類文件,做修改成為自己的分頁方法
    framework/web/widgets/pagers/CListPager.php復(fù)制并生命名到protected/components/zpager.php修改類名稱
    framework/web/widgets/pagers/pager.css復(fù)制對應(yīng)樣式文件到protected/components/css/pager.css
    修改zpager.php的css加載目錄
    public static function registerCssFile($url=null)
    {
     if($url===null)
      $url=CHtml::asset(Yii::getPathOfAlias('application.components.css.pager').'.css');
     Yii::app()->getClientScript()->registerCssFile($url);
    }
    3. 通過修改Css樣式文件,也可以修改生成列表的程序,達(dá)到修改分類的目的。
    希望本文所述對大家基于Yii框架的PHP程序設(shè)計有所幫助。