YII分页

 

'defaultOrder'=>array('title' => false), false是升序,true是倒叙

1.自定义分页

使用CPagination呈现相关信息到页码. 当数据需要渲染到多页时,我们可能使用去呈现信息,诸如itemCount, pageSize, currentPage,等等. 这些信息被传递到pagers

Java代码    收藏代码
  1. $sql = "SELECT * FROM USER";  
  2. $data = Yii::app()->db->createCommand($sql)->queryAll();  
  3.   
  4. $sql2 = "SELECT count(*) FROM USER";  
  5. $count = Yii::app()->db->createCommand($sql2)->queryScalar();  
  6.   
  7. $pages = new CPagination($count);                
  8. $pages->pageSize = 4;  
  9. //$pages->setCurrentPage(2);  
  10. $pdata =Yii::app()->db->createCommand($sql." LIMIT :offset,:limit");  
  11. $pdata->bindValue(':offset', $pages->currentPage*$pages->pageSize);//$pages->getOffset();  
  12. $pdata->bindValue(':limit', $pages->pageSize);//$pages->getLimit();  
  13. $info = $pdata->queryAll();  

PostController.php

Java代码    收藏代码
  1. <?php  
  2. class PostController extends Controller  
  3. {  
  4.     function actionIndex()  
  5.     {  
  6.         $criteria = new CDbCriteria();    
  7.         $criteria->compare("log_id",">0");   
  8.         $count=Ipad3SerialNumber::model()->count($criteria);    
  9.   
  10.         $pages=new CPagination($count);    
  11.         // elements per page    
  12.         $pages->pageSize=2;    
  13.         $pages->applyLimit($criteria);    
  14.   
  15.         // sorting    
  16.         $sort = new CSort('Ipad3SerialNumber');    
  17.         $sort->attributes = array(    
  18.             'number',  
  19.             'get_time'    
  20.         );  
  21.         $sort->defaultOrder = array('get_time'=>true);  
  22.         $sort->applyOrder($criteria);    
  23.   
  24.         $models = Ipad3SerialNumber::model()->findAll($criteria);    
  25.         $this->render('list', array(    
  26.             'models' => $models,    
  27.             'pages' => $pages,    
  28.             'sort' => $sort,    
  29.         ));   
  30.     }  
  31. }  

 view

Java代码    收藏代码
  1. <?php  
  2. <p><?php echo $sort->link('id')?></p>  
  3. <p><?php echo $sort->link('title')?></p>  
  4. <ol>  
  5. <?php foreach($models as $model):?>  
  6. <li>  
  7. <h2><?php echo $model->id?> - <?php echo $model->title?></h2>  
  8. </li>  
  9. <?php endforeach?>  
  10. </ol>  
  11. <?php $this->widget('CLinkPager', array(  
  12.     'pages' => $pages,  
  13.     'header'=>''  
  14. ));  
  15. $this->widget('CListPager', array(    
  16.     'pages'=>$pages,   
  17.     'header'=>'-'  
  18. ));  
  19. ?>  

点击$sort的link可以动态排序

 

2系统也有封装的分页 ,排序GRID

enableSorting=false全部禁用排序,单列禁用排序sortable =false,enablePagination=false

Java代码    收藏代码
  1. public function actionAR(){  
  2.     /****用法一:*****/  
  3.     $criteria = new CDbCriteria();    
  4.     $criteria->compare('serviceType',$arr);  
  5.     $dataProvider=new CActiveDataProvider('Post',array(  
  6.         'criteria' => $criteria,  
  7.     ));  
  8.   
  9.     /****用法二:*****/  
  10.     $dataProvider=new CActiveDataProvider('Post', array(  
  11.         /*'criteria'=>array( 
  12.             'condition'=>'status=1 AND tags like :tags', 
  13.             'params'=>array(':tags'=>$_GET['tags']), 
  14.             'order'=>'create_time DESC', 
  15.             'with'=>array('author'), 
  16.         ),*/  
  17.         'pagination'=>array(  
  18.             'pageSize'=>100,  
  19.         ),  
  20.         'sort'=>array(  
  21.             'defaultOrder'=> array('title'=>true),  
  22.         ),  
  23.     ));  
  24.     $this->render('index', array(  
  25.         'dataProvider' => $dataProvider,  
  26.     ));  
  27. }  
  28.   
  29. public function actionArray(){ //推荐不用,数组大内存溢出  
  30.     $rawData= array(array(  
  31.         'name'=>'István Beregszászi',  
  32.         'duty'=>'core framework development',  
  33.         'active'=>false,  
  34.     ));  
  35.     //$rawData=Yii::app()->db->createCommand($sql)->queryAll();  
  36.     $dataProvider = new CArrayDataProvider($rawData, array(  
  37.         'sort'=>array(  
  38.             'attributes'=>array('name''id''active'),  
  39.             'defaultOrder'=>array('active' => true'name' => false),  
  40.         ),  
  41.         'pagination'=>array(  
  42.             'pageSize'=>10,  
  43.         ),  
  44.     ));  
  45.     $this->render('index', array(  
  46.         'dataProvider' => $dataProvider,  
  47.     ));  
  48. }  
  49.   
  50. public function actionSQL(){  
  51.     $count = Yii::app()->db->createCommand('SELECT COUNT(*) FROM film')->queryScalar();  
  52.     $sql = 'SELECT film_id,title FROM film';  
  53.     $dataProvider=new CSqlDataProvider($sql,array(  
  54.         'keyField'=>'film_id',  //sql in select table column default id  
  55.         'totalItemCount'=>$count,  
  56.         'sort'=>array(  
  57.             'attributes'=>array('title'), //sql table columns  
  58.             'defaultOrder'=>array('title' => true),  
  59.         ),  
  60.         'pagination'=>array(  
  61.             'pageSize'=>100,  
  62.         ),  
  63.     ));  
  64.     $this->render('index', array(  
  65.         'dataProvider' => $dataProvider,  
  66.     ));  
  67. }  

 view

Java代码    收藏代码
  1. <?php foreach($dataProvider->data as $film):?>  
  2. <?php echo $film->title?>  
  3. <?php endforeach?>  
  4. <?php $this->widget('CLinkPager',array(  
  5. 'pages'=>$dataProvider->pagination))?>  

也可以套CGridView(推荐) summaryText,{summary}自定义总计信息

Java代码    收藏代码
  1. <?php  
  2. $this->widget('zii.widgets.grid.CGridView', array(  
  3.     'dataProvider'=>$dataProvider,  
  4.     'template'=>'{items}{summary}{pager}',  
  5.     'summaryText'=>"第{start}-{end}条, 共 {count} 条,页数:{page}/{pages}页",  
  6.     'columns'=>array(  
  7.         array(    
  8.             'name' => 'title',     
  9.             'header' => '订单号',   
  10.             'value'=>'$data[title]',  //if is_array  
  11.         )    
  12.     ),  
  13. ));?>  

PS:在CGridView中显示当前是第几页可以用: 

$this->grid->dataProvider->pagination->currentPage
 

 

3分页扩展

mypager是 一个非常简单的 扩展 , 结合在一个 CListPager 和 CLinkPager , 允许 用户选择 他们想要 去 或者点击 一个页面 按钮 CLinkPager ) , 或 选择 从 下拉列表中 的 页面 ( CListPager ) 页 CGridView 。 
CLinkPager首页,末页CSS默认不显示
Page.css代码    收藏代码
  1. /**  
  2.  * Hide first and last buttons by default.  
  3.  */  
  4. ul.yiiPager .first,  
  5. ul.yiiPager .last  
  6. {  
  7.     display:none;  
  8. }  

 

Java代码    收藏代码
  1. <?php $this->widget('zii.widgets.grid.CGridView', array(  
  2.     'id'=>'customer-grid',  
  3.     'dataProvider'=>$model->search(),  
  4.     'pager'=>array(  
  5.         //'class'=>'CLinkPager', //LinkListPager  
  6.         'maxButtonCount'=>8,  
  7.         'firstPageLabel'=>'首页',  
  8.         'lastPageLabel'=>'末页',  
  9.         'nextPageLabel'=>'下一页',  
  10.         'prevPageLabel'=>'上一页',  
  11.         'header'=>'',  
  12.         'cssFile'=>false,    //如果使用主css文件,那么这里可以写false,如果使用其它附加css文件,我们这里填写css文件名。  
  13.     ),   
  14. ));?>  

 转自:http://hudeyong926.iteye.com/blog/1320625

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值