YII 分页排序

简介:

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

1.自定义分页

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

Java代码   收藏代码
  1. //某一页的记录列表  
  2. public function getPagerList($modelClass, $page = 1, $where = '')  
  3. {  
  4.     $pageSize = Yii::app()->params['pagesize'];  
  5.     $offset = ($page - 1) * $pageSize;  
  6.       
  7.     $sql = $this->_listSql($modelClass, $where, '*');  
  8.     $command = Yii::app()->db->createCommand($sql . " LIMIT :offset,:limit");  
  9.     $command->bindValue(':offset', $offset);  
  10.     $command->bindValue(':limit', $pageSize);  
  11.     return $command->queryAll();  
  12. }  
  13.   
  14. private function _listSql($modelClass, $where, $field = 'COUNT(*)')  
  15. {  
  16.     $sql = "SELECT $field FROM " . CActiveRecord::model($modelClass)->tableSchema->name;  
  17.     if ($where) $sql .= " WHERE {$where}";  
  18.     return $sql;  
  19. }  
  20. //记录总数  
  21. public function getCount($modelClass, $where = "")  
  22. {  
  23.     $sql = $this->_listSql($modelClass, $where);  
  24.     return Yii::app()->db->createCommand($sql)->queryScalar();  
  25. }  
  26.   
  27. $pages = new CPagination($count);                
  28. $pages->pageSize = 4;  
  29. //$pages->setCurrentPage($page-1);  
  30. $pdata =Yii::app()->db->createCommand($sql." LIMIT :offset,:limit");  
  31. $pdata->bindValue(':offset', $pages->getOffset();  
  32. $pdata->bindValue(':limit', $pages->getLimit());  
  33. $info = $pdata->queryAll();  

CActiveDataProvider不使用分页,取所有记录

Java代码   收藏代码
  1. $model = Orders::model();  
  2. if (isset($_GET['Orders'])) {  
  3.     $model->attributes = $_GET['Orders'];  
  4. }  
  5. $dataProvider = $model->search();  
  6. $dataProvider->setPagination(false); //禁用分页  
  7. $listAll = $dataProvider->getData();  

PostController.php

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

 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系统也有封装的分页 ,排序GRIDView 覆盖public $pager = 'CardPager'属性和renderPager()方法

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. ));?>  

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. ));?>  
 
相关文章
|
前端开发 API 数据安全/隐私保护
DRF--分页
DRF--分页
|
SQL Oracle 关系型数据库
什么是分页?如何使用分页?(一)
什么是分页?如何使用分页?
183 0
|
SQL Oracle 关系型数据库
第5章_排序与分页
第5章_排序与分页
51 0
|
SQL 前端开发
JavaWeb12(实现基础分页&模糊查询的分页)
JavaWeb12(实现基础分页&模糊查询的分页)
【Django学习】(十二)GenericAPIView_过滤_排序_分页(上)
【Django学习】(十二)GenericAPIView_过滤_排序_分页
【Django学习】(十二)GenericAPIView_过滤_排序_分页(上)
【Django学习】(十二)GenericAPIView_过滤_排序_分页(下)
【Django学习】(十二)GenericAPIView_过滤_排序_分页(下)
|
SQL 存储 关系型数据库
什么是分页?如何使用分页?(二)
什么是分页?如何使用分页?
76 0
|
SQL Oracle 关系型数据库
第05章_排序与分页
第05章_排序与分页
89 0