yii分页组件用法实例分析


Posted in PHP onDecember 28, 2015

本文实例讲述了yii分页组件用法。分享给大家供大家参考,具体如下:

该案例使用时,分页类在yii框架中以组件的形式存在于components中。

action代码如下:

public function actionIndex(){
  $user=User::model();
  //分页的使用
  $count=$user->count(); //获取总页数
  $pagesize=3; //每一页显示的记录条数
  $page=new Page($count,$pagesize);
  $sql="select * from {{user}} $page->limit";
  $info=$user->findAllBySql($sql);
  $show_page=$page->fpage();
  $this->renderPartial("index",array("info"=>$info,'show_page'=>$show_page));
}

在view页面,遍历info即可获取信息,输出show_page即可显示分页列表等信息。

现附上page.php代码如下:

<?php
/**
 * 分页类,以组件形式存在于componnets文件中
 */
class Page {
  private $total; //数据表中总记录数
  private $listRows; //每页显示行数
  private $limit;
  private $uri;
  private $pageNum; //页数
  private $config=array('header'=>"个记录", "prev"=>"上一页", "next"=>"下一页", "first"=>"首 页", "last"=>"尾 页");
  private $listNum=8;
  /*
   * $total
   * $listRows
   */
  public function __construct($total, $listRows=10, $pa=""){
   $this->total=$total;
   $this->listRows=$listRows;
   $this->uri=$this->getUri($pa);
   $this->page=!empty($_GET["page"]) ? $_GET["page"] : 1;
   $this->pageNum=ceil($this->total/$this->listRows);
   $this->limit=$this->setLimit();
  }
  private function setLimit(){
   return "Limit ".($this->page-1)*$this->listRows.", {$this->listRows}";
  }
  private function getUri($pa){
   $url=$_SERVER["REQUEST_URI"].(strpos($_SERVER["REQUEST_URI"], '?')?'':"?").$pa;
   $parse=parse_url($url);
   if(isset($parse["query"])){
    parse_str($parse['query'],$params);
    unset($params["page"]);
    $url=$parse['path'].'?'.http_build_query($params);
   }
   return $url;
  }
  function __get($args){
   if($args=="limit")
    return $this->limit;
   else
    return null;
  }
  private function start(){
   if($this->total==0)
    return 0;
   else
    return ($this->page-1)*$this->listRows+1;
  }
  private function end(){
   return min($this->page*$this->listRows,$this->total);
  }
  private function first(){
      $html='';
   if($this->page==1)
    $html.='';
   else
    $html.=" <a href='{$this->uri}&page=1'>{$this->config["first"]}</a> ";
   return $html;
  }
  private function prev(){
      $html='';
   if($this->page==1)
    $html.='';
   else
    $html.=" <a href='{$this->uri}&page=".($this->page-1)."'>{$this->config["prev"]}</a> ";
   return $html;
  }
  private function pageList(){
   $linkPage="";
   $inum=floor($this->listNum/2);
   for($i=$inum; $i>=1; $i--){
    $page=$this->page-$i;
    if($page<1)
     continue;
    $linkPage.=" <a href='{$this->uri}&page={$page}'>{$page}</a> ";
   }
   $linkPage.=" {$this->page} ";
   for($i=1; $i<=$inum; $i++){
    $page=$this->page+$i;
    if($page<=$this->pageNum)
     $linkPage.=" <a href='{$this->uri}&page={$page}'>{$page}</a> ";
    else
     break;
   }
   return $linkPage;
  }
  private function next(){
      $html='';
   if($this->page==$this->pageNum)
    $html.='';
   else
    $html.=" <a href='{$this->uri}&page=".($this->page+1)."'>{$this->config["next"]}</a> ";
   return $html;
  }
  private function last(){
      $html='';
   if($this->page==$this->pageNum)
    $html.='';
   else
    $html.=" <a href='{$this->uri}&page=".($this->pageNum)."'>{$this->config["last"]}</a> ";
   return $html;
  }
  private function goPage(){
   return ' <input type="text" onkeydown="javascript:if(event.keyCode==13){var page=(this.value>'.$this->pageNum.')?'.$this->pageNum.':this.value;location=\''.$this->uri.'&page=\'+page+\'\'}" value="'.$this->page.'" style="width:25px"><input type="button" value="GO" onclick="javascript:var page=(this.previousSibling.value>'.$this->pageNum.')?'.$this->pageNum.':this.previousSibling.value;location=\''.$this->uri.'&page=\'+page+\'\'"> ';
  }
  function fpage($display=array(0,1,2,3,4,5,6,7,8)){
   $html[0]=" 共有<b>{$this->total}</b>{$this->config["header"]} ";
   $html[1]=" 每页显示<b>".($this->end()-$this->start()+1)."</b>条,本页<b>{$this->start()}-{$this->end()}</b>条 ";
   $html[2]=" <b>{$this->page}/{$this->pageNum}</b>页 ";
   $html[3]=$this->first();
   $html[4]=$this->prev();
   $html[5]=$this->pageList();
   $html[6]=$this->next();
   $html[7]=$this->last();
   $html[8]=$this->goPage();
   $fpage='';
   foreach($display as $index){
    $fpage.=$html[$index];
   }
   return $fpage;
  }
}

希望本文所述对大家基于yii框架的PHP程序设计有所帮助。

PHP 相关文章推荐
如何在symfony中导出为CSV文件中的数据
Oct 06 PHP
对于PHP 5.4 你必须要知道的
Aug 07 PHP
php将mysql数据库整库导出生成sql文件的具体实现
Jan 08 PHP
php中自定义函数dump查看数组信息类似var_dump
Jan 27 PHP
PHP异常处理Exception类
Dec 11 PHP
简单了解WordPress开发中update_option()函数的用法
Jan 11 PHP
php获取客户端IP及URL的方法示例
Feb 03 PHP
php的优点总结 php有哪些优点
Jul 19 PHP
laravel-admin 在列表页添加自定义按钮的例子
Sep 30 PHP
Laravel 类和接口注入相关的代码
Oct 15 PHP
Yii框架getter与setter方法功能与用法分析
Oct 22 PHP
php将字符串转换为数组实例讲解
May 05 PHP
PHP读取文件内容的五种方式
Dec 28 #PHP
yii用户注册表单验证实例
Dec 26 #PHP
PHP7之Mongodb API使用详解
Dec 26 #PHP
thinkPHP下的widget扩展用法实例分析
Dec 26 #PHP
thinkPHP下ueditor的使用方法详解
Dec 26 #PHP
thinkPHP中分页用法实例分析
Dec 26 #PHP
thinkPHP中验证码的简单使用方法
Dec 26 #PHP
You might like
php,不用COM,生成excel文件
2006/10/09 PHP
如何过滤高亮显示非法字符
2006/10/09 PHP
使用Xdebug调试和优化PHP程序之[1]
2007/04/17 PHP
PHP序列号生成函数和字符串替换函数代码
2012/06/07 PHP
php var_export与var_dump 输出的不同
2013/08/09 PHP
PHP观察者模式示例【Laravel框架中有用到】
2018/06/15 PHP
PHP使用OB缓存实现静态化功能示例
2019/03/23 PHP
Yii框架使用PHPExcel导出Excel文件的方法分析【改进版】
2019/07/24 PHP
由JavaScript技术实现的web小游戏(不含网游)
2010/06/12 Javascript
测试IE浏览器对JavaScript的AngularJS的兼容性
2015/06/19 Javascript
超赞的jQuery图片滑块动画特效代码汇总
2016/01/25 Javascript
基于jQuery Easyui实现登陆框界面
2017/07/10 jQuery
浅谈vue-cli 3.0.x 初体验
2018/04/11 Javascript
vue 点击按钮增加一行的方法
2018/09/07 Javascript
webpack+vue+express(hot)热启动调试简单配置方法
2018/09/19 Javascript
Node.js原生api搭建web服务器的方法步骤
2019/02/15 Javascript
手把手教你使用TypeScript开发Node.js应用
2019/05/06 Javascript
通过vue手动封装on、emit、off的代码详解
2019/05/29 Javascript
javascript/jquery实现点击触发事件的方法分析
2019/11/11 jQuery
基于javascript处理nginx请求过程详解
2020/07/07 Javascript
[51:06]2018DOTA2亚洲邀请赛3月29日 小组赛A组 KG VS Liquid
2018/03/30 DOTA
python 全文检索引擎详解
2017/04/25 Python
Python实现对字符串的加密解密方法示例
2017/04/29 Python
利用python获取当前日期前后N天或N月日期的方法示例
2017/07/30 Python
python数据类型判断type与isinstance的区别实例解析
2017/10/31 Python
Python读取配置文件(config.ini)以及写入配置文件
2020/04/08 Python
Ubuntu16安装Python3.9的实现步骤
2020/12/15 Python
前端制作动画的几种方式(css3,js)
2016/12/12 HTML / CSS
css3 按钮样式简单可扩展创建
2013/03/18 HTML / CSS
html5教程制作简单画板代码分享
2013/12/04 HTML / CSS
实习单位评语
2014/04/26 职场文书
高中教师考核方案
2014/05/18 职场文书
预防艾滋病宣传标语
2014/06/25 职场文书
财会专业大学生求职信
2014/09/26 职场文书
Pytorch 实现变量类型转换
2021/05/17 Python
element多个表单校验的实现
2021/05/27 Javascript