PHP超强分页类2.0使用心得

刚转向学习PHP没多久,基于以前ASP学习的习惯,在进行了PHP语法的熟悉之后就开始翻腾PHP高人们的类库,第一个要找的当然是分页类了,找来找去都说分飞写的超强分页类2.0不错,到phpchina拷下来测试了一下遇到很多问题,网上又没有完整的DEMO.所以就自己根据使用心得写了一个DEMO,望多批评:)

所用文件:

cls_data.php/*数据库操作类(也是从网上找别人的,嘿嘿)*/

cls_page.php/*分飞的超强分页类2.0*/

demo.php/*演示*/

start:======================cls_data.php===========================


<?php
##########################################
########mysql数据库操作类#################
########source:网络,data:2007年12月21日###
########drckness,QQ:191673312#############
##########################################
class DB{
   var $db_host;
   var $db_user;
   var $db_password;
   var $db_database;
   var $result;
   var $conn;
   var $sql;//便于调实
var $row;
//构造空函数
function DB($db_host,$db_user,$db_password,$db_database){
    $this->db_host = $db_host;
    $this->db_user = $db_user;
    $this->db_password = $db_password;
    $this->db_database = $db_database;
   }
//连接数据库
function conn(){
    $conn = mysql_connect($this->db_host,$this->db_user,$this->db_password);
     if(!$conn){
      $this->msg_error("无法连接数据库");
     }else{
      $this->conn = $conn;
     }
     if(!mysql_select_db($this->db_database,$this->conn)){
     $this->msg_error("无法选择数据库");
     }
     return $this->conn;
   }
//更新数据库,包括数据添加,更新
function query_noResult($sql){
     if("" == $sql){$this->msg_error("传递了一个空变量");}
    $this->sql = $sql;
    //echo $this->sql;
     //echo $this->conn;
    if(!mysql_db_query($this->db_database,$this->sql,$this->conn)){
     $this->msg_error(("数据更新过程发生错误!"));
     }
     return null;
   }
//查询数据并返回result类型
function query_withResult($sql){
     if("" == $sql){$this->msg_error("传递了一个空变量");}
    $this->sql = $sql;
    // $conn = mysql_connect("localhost","root","");
    $result = mysql_db_query($this->db_database,$this->sql,$this->conn);
     //不过是写成了reslut
   
    if(!$result){
      $this->msg_error("数据查询过程发生错误或空记录!");
     }else{
      $this->result = $result;
     }
    //使用时,可以直接引用成员变量而无须关心返回值,除非需要返回值
     //做更多处理
    return $this->result;
   }
//释放结果集
function free(){
    mysql_free_result($this->result);
   }
//关闭连接
function close(){
     if($this->result){
      $this->free();
     }
    mysql_close($this->conn);
   }
// 根据执行结果取得影响行数
function db_affected_rows(){
     return mysql_affected_rows();
   }
// 根据查询结果计算结果集条数
function db_num_rows(){
     if($this->result==null){
      $this->msg_error("记录为空!");
     }
     return mysql_num_rows($this->result);
   }
//取得记录集
function db_fetch_array(){
     if($this->result==null){
      //$this->msg_error("您查询的记录为空!");
    }
    $this->row = @mysql_fetch_array($this->result);
     return $this->row;
   }
//指向确定的一条数据记录
   //通用数据库错误处理
function db_data_seek($result,$i){
    mysql_data_seek($result,$i);
     return $this->result;
   }
   function msg_error($message){
    $time = date("Y年m月d日 H时i分s秒");
     echo "很抱歉您操作数据库时发生了错误<br>";
     echo "发生错误时间:".$time."<br>";
     echo "错误信息:".$message."<br>";
     echo "请联系QQ:191673312..谢谢!";
    // exit();
}
}
?>

end:======================cls_data.php===========================

 

start:======================cls_page.php===========================

 

<?php
/**
* filename: ext_page.class.php
* @package:phpbean
* @author :feifengxlq<feifengxlq#gmail.com><[url=http://www.phpobject.net/]http://www.phpobject.net/[/url]>
* @copyright :Copyright 2006 feifengxlq
* @license:version 2.0
* @create:2006-5-31
* @modify:2006-6-1
* @modify:feifengxlq 2006-11-4
* description:超强分页类,四种分页模式,默认采用类似baidu,google的分页风格。
* 2.0增加功能:支持自定义风格,自定义样式,同时支持PHP4和PHP5,
* to see detail,please visit [url=http://www.phpobject.net/blog/read.php]http://www.phpobject.net/blog/read.php[/url]?
* example:
* 模式四种分页模式:
   require_once('../libs/classes/page.class.php');
   $page=new page(array('total'=>1000,'perpage'=>20));
   echo 'mode:1<br>'.$page->show();
   echo '<hr>mode:2<br>'.$page->show(2);
   echo '<hr>mode:3<br>'.$page->show(3);
   echo '<hr>mode:4<br>'.$page->show(4);
   开启AJAX:
   $ajaxpage=new page(array('total'=>1000,'perpage'=>20,'ajax'=>'ajax_page','page_name'=>'test'));
   echo 'mode:1<br>'.$ajaxpage->show();
   采用继承自定义分页显示模式:
   demo:[url=http://www.phpobject.net/blog]http://www.phpobject.net/blog[/url]
   ########drckness,QQ:191673312,修改#############
*/
class page
{
/**
* config ,public
*/
var $page_name="PB_page";//page标签,用来控制url页。比如说xxx.php?PB_page=2中的PB_page
var $next_page='>';//下一页
var $pre_page='<';//上一页
var $first_page='First';//首页
var $last_page='Last';//尾页
var $pre_bar='<<';//上一分页条
var $next_bar='>>';//下一分页条
var $format_left='[';
var $format_right=']';
var $is_ajax=false;//是否支持AJAX分页模式

/**
* private
*
*/
var $pagebarnum=10;//控制记录条的个数。
var $totalpage=0;//总页数
var $ajax_action_name='';//AJAX动作名
var $nowindex=1;//当前页
var $url="";//url地址头
var $offset=0;

/**
* constructor构造函数
*
* @param array $array['total'],$array['perpage'],$array['nowindex'],$array['url'],$array['ajax']...
*/
function page($array)
{
if(is_array($array)){
     if(!array_key_exists('total',$array))$this->error(__FUNCTION__,'need a param of total');
     $total=intval($array['total']);
     $perpage=(array_key_exists('perpage',$array))?intval($array['perpage']):10;
     $nowindex=(array_key_exists('nowindex',$array))?intval($array['nowindex']):'';
     $url=(array_key_exists('url',$array))?$array['url']:'';
}else{
     $total=$array;
     $perpage=10;
     $nowindex='';
     $url='';
}
if((!is_int($total))||($total<0))$this->error(__FUNCTION__,$total.' is not a positive integer!');
if((!is_int($perpage))||($perpage<=0))$this->error(__FUNCTION__,$perpage.' is not a positive integer!');
if(!empty($array['page_name']))$this->set('page_name',$array['page_name']);//设置pagename
$this->_set_nowindex($nowindex);//设置当前页
$this->_set_url($url);//设置链接地址
$this->totalpage=ceil($total/$perpage);
$this->offset=($this->nowindex-1)*$perpage;
if(!empty($array['ajax']))$this->open_ajax($array['ajax']);//打开AJAX模式
}
/**
* 设定类中指定变量名的值,如果改变量不属于这个类,将throw一个exception
*
* @param string $var
* @param string $value
*/
function set($var,$value)
{
if(in_array($var,get_object_vars($this)))
     $this->$var=$value;
else {
   $this->error(__FUNCTION__,$var." does not belong to PB_Page!");
}

}
/**
* 打开倒AJAX模式
*
* @param string $action 默认ajax触发的动作。
*/
function open_ajax($action)
{
$this->is_ajax=true;
$this->ajax_action_name=$action;
}
/**
* 获取显示"下一页"的代码
*
* @param string $style
* @return string
*/
function next_page($style='')
{
if($this->nowindex<$this->totalpage){
   return $this->_get_link($this->_get_url($this->nowindex+1),$this->next_page,$style);
}
return '<span class="'.$style.'">'.$this->next_page.'</span>';
}

/**
* 获取显示“上一页”的代码
*
* @param string $style
* @return string
*/
function pre_page($style='')
{
if($this->nowindex>1){
   return $this->_get_link($this->_get_url($this->nowindex-1),$this->pre_page,$style);
}
return '<span class="'.$style.'">'.$this->pre_page.'</span>';
}

/**
* 获取显示“首页”的代码
*
* @return string
*/
function first_page($style='')
{
if($this->nowindex==1){
      return '<span class="'.$style.'">'.$this->first_page.'</span>';
}
return $this->_get_link($this->_get_url(1),$this->first_page,$style);
}

/**
* 获取显示“尾页”的代码
*
* @return string
*/
function last_page($style='')
{
if($this->nowindex==$this->totalpage){
      return '<span class="'.$style.'">'.$this->last_page.'</span>';
}
return $this->_get_link($this->_get_url($this->totalpage),$this->last_page,$style);
}

function nowbar($style='',$nowindex_style='')
{
$plus=ceil($this->pagebarnum/2);
if($this->pagebarnum-$plus+$this->nowindex>$this->totalpage)$plus=($this->pagebarnum-$this->totalpage+$this->nowindex);
$begin=$this->nowindex-$plus+1;
$begin=($begin>=1)?$begin:1;
$return='';
for($i=$begin;$i<$begin+$this->pagebarnum;$i++)
{
   if($i<=$this->totalpage){
    if($i!=$this->nowindex)
        $return.=$this->_get_text($this->_get_link($this->_get_url($i),$i,$style));
    else
        $return.=$this->_get_text('<span class="'.$nowindex_style.'">'.$i.'</span>');
   }else{
    break;
   }
   $return.="/n";
}
unset($begin);
return $return;
}
/**
* 获取显示跳转按钮的代码
*
* @return string
*/
function select()
{
   $return='';
for($i=1;$i<=$this->totalpage;$i++)
{
   if($i==$this->nowindex){
    $return.='<option value="'.$i.'" selected>'.$i.'</option>';
   }else{
    $return.='<option value="'.$i.'">'.$i.'</option>';
   }
}
unset($i);
$return.='</select>';
return $return;
}

/**
* 获取mysql 语句中limit需要的值
*
* @return string
*/
function offset()
{
return $this->offset;
}

/**
* 控制分页显示风格(你可以增加相应的风格)
*
* @param int $mode
* @return string
*/
function show($mode=1)
{
switch ($mode)
{
   case '1':
    $this->next_page='下一页';
    $this->pre_page='上一页';
    return '<script language="javascript" type="text/javascript">
function changecs(page_num){
document.location.href="?PB_page="+page_num;
}
</script><form name="myform">'.$this->pre_page().$this->nowbar().$this->next_page().''.'<select name="PB_Page_Select" onChange=changecs(document.myform.PB_Page_Select.options[document.myform.PB_Page_Select.selectedIndex].value) id="PB_Page_Select">'.$this->select().'</form>';
    break;
   case '2':
    $this->next_page='下一页';
    $this->pre_page='上一页';
    $this->first_page='首页';
    $this->last_page='尾页';
    return $this->first_page().$this->pre_page().'[第'.$this->nowindex.'页]'.$this->next_page().$this->last_page().'第'.$this->select().'页';
    break;
   case '3':
    $this->next_page='下一页';
    $this->pre_page='上一页';
    $this->first_page='首页';
    $this->last_page='尾页';
    return $this->first_page().$this->pre_page().$this->next_page().$this->last_page();
    break;
   case '4':
    $this->next_page='下一页';
    $this->pre_page='上一页';
    return $this->pre_page().$this->nowbar().$this->next_page();
    break;
   case '5':
    return $this->pre_bar().$this->pre_page().$this->nowbar().$this->next_page().$this->next_bar();
    break;
}

}
/*----------------private function (私有方法)-----------------------------------------------------------*/
/**
* 设置url头地址
* @param: String $url
* @return boolean
*/
function _set_url($url="")
{
if(!empty($url)){
      //手动设置
   $this->url=$url.((stristr($url,'?'))?'&':'?').$this->page_name."=";
}else{
      //自动获取
   if(empty($_SERVER['QUERY_STRING'])){
       //不存在QUERY_STRING时
    $this->url=$_SERVER['REQUEST_URI']."?".$this->page_name."=";
   }else{
       //
    if(stristr($_SERVER['QUERY_STRING'],$this->page_name.'=')){
        //地址存在页面参数
     $this->url=str_replace($this->page_name.'='.$this->nowindex,'',$_SERVER['REQUEST_URI']);
     $last=$this->url[strlen($this->url)-1];
     if($last=='?'||$last=='&'){
         $this->url.=$this->page_name."=";
     }else{
         $this->url.='&'.$this->page_name."=";
     }
    }else{
        //
     $this->url=$_SERVER['REQUEST_URI'].'&'.$this->page_name.'=';
    }//end if   
   }//end if
}//end if
}

/**
* 设置当前页面
*
*/
function _set_nowindex($nowindex)
{
if(empty($nowindex)){
   //系统获取
  
   if(isset($_GET[$this->page_name])){
    $this->nowindex=intval($_GET[$this->page_name]);
   }
}else{
      //手动设置
   $this->nowindex=intval($nowindex);
}
}

/**
* 为指定的页面返回地址值
*
* @param int $pageno
* @return string $url
*/
function _get_url($pageno=1)
{
return $this->url.$pageno;
}

/**
* 获取分页显示文字,比如说默认情况下_get_text('<a href="">1</a>')将返回[<a href="">1</a>]
*
* @param String $str
* @return string $url
*/
function _get_text($str)
{
return $this->format_left.$str.$this->format_right;
}

/**
   * 获取链接地址
*/
function _get_link($url,$text,$style=''){
$style=(empty($style))?'':'class="'.$style.'"';
if($this->is_ajax){
      //如果是使用AJAX模式
   return '<a '.$style.' href="javascript:'.$this->ajax_action_name.'(/''.$url.'/')">'.$text.'</a>';
}else{
   return '<a '.$style.' href="'.$url.'">'.$text.'</a>';
}
}
/**
   * 出错处理方式
*/
function error($function,$errormsg)
{
     die('Error in file <b>'.__FILE__.'</b> ,Function <b>'.$function.'()</b> :'.$errormsg);
}
}
?>

end:======================cls_page.php===========================

 

 

start:======================Demo.php===========================

 

<?php
/*
$page=new page(array('total'=>1000,'perpage'=>20));
echo 'mode:1<br>'.$page->show();
echo '<hr>mode:2<br>'.$page->show(2);
echo '<hr>mode:3<br>'.$page->show(3);
echo '<hr>mode:4<br>'.$page->show(4);
echo '<hr>开始AJAX模式:';
$ajaxpage=new page(array('total'=>1000,'perpage'=>20,'ajax'=>'ajax_page','page_name'=>'test'));
echo 'mode:1<br>'.$ajaxpage->show();
*/

include_once 'cls_data.php';//数据库操作类
require_once 'cls_page.php'; //分飞分页类

    $db = new DB("localhost","root","123456","test"); //连接数据库
$db->conn();

    $pageindex=1;   //设置初始页数
    if( isset($_GET['PB_page']) ){ //判断取得的页数
        $pageindex = $_GET['PB_page'];  
    }  

    $sql_count="select count(*) as tt from admin";//取得行数
    $rs=$db->query_withResult($sql_count);

$counts =mysql_fetch_object($rs)->tt;//取得行数
$pagesize=10;//每页显示的数据条目数

    $page=new page(array('total'=>$counts,'perpage'=>$pagesize));   //实例化分页类,初始化构造函数中的总条目数和每页显示条目数
  
    $sql="select * from admin limit ".($pageindex-1)*$pagesize .",$pagesize";   

    $rss = $db->query_withResult($sql);//返回记录集

    if($counts<1){  
        echo "Result is nothing";  
        exit();
}else{
   while($rs=mysql_fetch_object($rss)){//将该记录集返回给$rs对象读出
   echo $rs->Id."|".$rs->username."|".$rs->password."<br>";//对象区分大小写
      }
   echo '<br>'.$page->show();//输出分页
}

?>

 

end:======================Demo.php===========================

 

 

 

by:drckness

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 8
    评论
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值