首页 > 编程知识 正文

php分页类代码和使用(php分页函数)

时间:2023-12-20 16:55:05 阅读:318479 作者:FHIY

本文目录一览:

php分页代码

?php

// 首页 上一页 1 2 3 4 5 下一页 末页

class StrPage{

private $file;//文件内容

private $current;//当前页

private $totalPage;//总的页数

private $url;//url地址

private $pageLen;//每页显示的内容长度

function __construct($file,$len=500){

$this-file = file_get_contents($file);

$this-current=isset($_GET['page'])?$_GET['page']:1;

$this-pageLen = $len;

$this-totalPage = $this-getTotalPage();

$this-url= $this-getUrl();

}

private function getTotalPage(){

return ceil(strlen($this-file)/$this-pageLen);

}

private function getUrl(){

$url =parse_url($_SERVER['REQUEST_URI']);

parse_str($url['query'],$queryArr);

unset($queryArr['page']);

$queryStr = http_build_query($queryArr);

return $url['path'].'?'.$queryStr.'page=';

}

private function first(){

if($this-current1)return "a href='".$this-url."1'首页/a";

}

private function pre(){

if($this-current1)return "a href='".$this-url.($this-current-1)."'上一页/a";

}

private function next(){

if($this-current$this-totalPage)return "a href='".$this-url.($this-current+1)."'下一页/a";

}

private function end(){

if($this-current$this-totalPage) return "a href='".$this-url.$this-totalPage."'末页/a";

}

private function pageList(){

for ($i=1;$i=$this-totalPage;$i++){

if($i==$this-current){

$pageListStr.="span style='font-size:20px;color:#f00'".$i."/span ";

}else{

$pageListStr.="a href='".$this-url.$i."'".$i." /a";

}

}

return $pageListStr;

}

public function pageStyle($style=1){

switch ($style){

case 1:

return "共有".$this-totalPage."页".$this-first().$this-pre().$this-pageList().$this-next().$this-end();

break;

case 2;

return $this-pageList();

break;

}

}

public function getContents(){

$prePageLen = strlen($this-subStrs($this-current-1));

$currentPageLen = strlen($this-subStrs($this-current));

return substr($this-file, $prePageLen,$currentPageLen-$prePageLen);

}

private function subStrs($page){

$len= $page*$this-pageLen;

for ($i = 0; $i $len; $i++) {

if(ord(substr($this-file,$i,1))0xa0){

$string.=substr($this-file,$i,2);

$i++;

}else{

$string.=substr($this-file,$i,1);

}

}

return $string;

}

}

$php = new StrPage('75.txt',2000);

echo "div style='font-size:14px;line-height:1.8em;color:#666;padding:6px;width:960px;height:450px;'".$php-getContents()."/div";

echo "div style='border:solid 1px #ccc;font-size:14px;color:#333'";

echo $php-pageStyle();

echo "/div";

求PHP各种分页方法,各位大仙有的别藏了~~

PHP分页方法:

第一步创建一个类 subPages.php?php

class SubPages{

private $each_disNums;//每页显示的条目数

private $nums;//总条目数

private $current_page;//当前被选中的页

private $sub_pages;//每次显示的页数

private $pageNums;//总页数

private $page_array = array();//用来构造分页的数组

private $subPage_link;//每个分页的链接

private $subPage_type;//显示分页的类型

//__construct是SubPages的构造函数,用来在创建类的时候自动运行. //@$each_disNums 每页显示的条目数 // @nums 总条目数 // @current_num 当前被选中的页 //@sub_pages 每次显示的页数 // @subPage_link 每个分页的链接 //@subPage_type 显示分页的类型 //当@subPage_type=1的时候为普通分页模式 example: 共4523条记录,每页显示10条,当前第1/453页 [首页] [上页] [下页] [尾页] //当@subPage_type=2的时候为经典分页样式 example: 当前第1/453页 [首页] [上页] 1 2 3 4 5 6 7 8 9 10 [下页] [尾页]

function __construct($each_disNums,$nums,$current_page,$sub_pages,$subPage_link,$subPage_type){

//intval通过使用特定的进制转换(默认是十进制),返回变量 var 的 integer 数值

$this-each_disNums=intval($each_disNums);

$this-nums=intval($nums);

if(!$current_page){

$this-current_page=1;

}else{

$this-current_page=intval($current_page);

}

$this-sub_pages=intval($sub_pages);

$this-pageNums=ceil($nums/$each_disNums);

$this-subPage_link=$subPage_link;

$this-show_SubPages($subPage_type);

//echo $this-pageNums."--".$this-sub_pages;

}

//__destruct析构函数,当类不在使用的时候调用,该函数用来释放资源

function __destruct(){

unset($each_disNums);

unset($nums);

unset($current_page);

unset($sub_pages);

unset($pageNums);

unset($page_array);

unset($subPage_link);

unset($subPage_type);

}

//show_SubPages函数用在构造函数里面。而且用来判断显示什么样子的分页

function show_SubPages($subPage_type){

if($subPage_type == 1){

$this-subPageCss1();

}elseif ($subPage_type == 2){

$this-subPageCss2();

}

}

//用来给建立分页的数组初始化的函数。

function initArray(){

for($i=0;$i$this-sub_pages;$i++){

$this-page_array[$i]=$i;

}

return $this-page_array;

}

//construct_num_Page该函数使用来构造显示的条目

// 即使:[1][2][3][4][5][6][7][8][9][10]

function construct_num_Page(){

if($this-pageNums $this-sub_pages){

$current_array=array();

for($i=0;$i$this-pageNums;$i++){

$current_array[$i]=$i+1;

}

}else{

$current_array=$this-initArray();

if($this-current_page = 3){

for($i=0;$icount($current_array);$i++){

$current_array[$i]=$i+1;

}

}elseif ($this-current_page = $this-pageNums $this-current_page $this-pageNums - $this-sub_pages +1 ){

for($i=0;$icount($current_array);$i++){

$current_array[$i]=($this-pageNums)-($this-sub_pages)+1+$i;

}

}else{

for($i=0;$icount($current_array);$i++){

$current_array[$i]=$this-current_page-2+$i;

}

}

}

return $current_array;

}

//构造普通模式的分页

//共4523条记录,每页显示10条,当前第1/453页 [首页] [上页] [下页] [尾页]

function subPageCss1(){

$subPageCss1Str="";

$subPageCss1Str.="共".$this-nums."条记录,";

$subPageCss1Str.="每页显示".$this-each_disNums."条,";

$subPageCss1Str.="当前第".$this-current_page."/".$this-pageNums."页 ";

if($this-current_page 1){

$firstPageUrl=$this-subPage_link."1";

$prewPageUrl=$this-subPage_link.($this-current_page-1);

$subPageCss1Str.="[a href='$firstPageUrl'首页/a] ";

$subPageCss1Str.="[a href='$prewPageUrl'上一页/a] ";

}else {

$subPageCss1Str.="[首页] ";

$subPageCss1Str.="[上一页] ";

}

if($this-current_page $this-pageNums){

$lastPageUrl=$this-subPage_link.$this-pageNums;

$nextPageUrl=$this-subPage_link.($this-current_page+1);

$subPageCss1Str.=" [a href='$nextPageUrl'下一页/a] ";

$subPageCss1Str.="[a href='$lastPageUrl'尾页/a] ";

}else {

$subPageCss1Str.="[下一页] ";

$subPageCss1Str.="[尾页] ";

}

echo $subPageCss1Str;

}

//构造经典模式的分页

//当前第1/453页 [首页] [上页] 1 2 3 4 5 6 7 8 9 10 [下页] [尾页]

function subPageCss2(){

$subPageCss2Str="";

$subPageCss2Str.="当前第".$this-current_page."/".$this-pageNums."页 ";

if($this-current_page 1){

$firstPageUrl=$this-subPage_link."1";

$prewPageUrl=$this-subPage_link.($this-current_page-1);

$subPageCss2Str.="[a href='$firstPageUrl'首页/a] ";

$subPageCss2Str.="[a href='$prewPageUrl'上一页/a] ";

}else {

$subPageCss2Str.="[首页] ";

$subPageCss2Str.="[上一页] ";

}

$a=$this-construct_num_Page();

for($i=0;$icount($a);$i++){

$s=$a[$i];

if($s == $this-current_page ){

$subPageCss2Str.="[span style='color:red;font-weight:bold;'".$s."/span]";

}else{

$url=$this-subPage_link.$s;

$subPageCss2Str.="[a href='$url'".$s."/a]";

}

}

if($this-current_page $this-pageNums){

$lastPageUrl=$this-subPage_link.$this-pageNums;

$nextPageUrl=$this-subPage_link.($this-current_page+1);

$subPageCss2Str.=" [a href='$nextPageUrl'下一页/a] ";

$subPageCss2Str.="[a href='$lastPageUrl'尾页/a] ";

}else {

$subPageCss2Str.="[下一页] ";

$subPageCss2Str.="[尾页] ";

}

echo $subPageCss2Str;

}

}

?要做分页的页面?php//每页显示的条数

$page_size=2;

//得到当前是第几页

$pageCurrent=$_GET["p"];

$offet =($pageCurrent-1)*$page_size;

//建立数据库连接

$conn = mysql_connect("地址","用户名","密码") or die("".mysql_error());

//设置字符集

mysql_query("set names gbk");

//设置数据库

mysql_select_db("数据库名",$conn) or die("".mysql_error());

if($conn) { include ("query.html");

//查询会员信息//注:这里的sql查询了两遍.第一遍是确定查询出来的总数据条数

$query_sql = "SELECT * FROM user_info_t order by id desc";//第二遍是根据需要即$page_size来确定每次查出的条数

$query_sql_sec= "SELECT * FROM user_info_t order by id desc limit $offet,$page_size";

//执行查询语句 返回一个结果集

$query_res = mysql_query($query_sql,$conn);

$query_res_sec = mysql_query($query_sql_sec,$conn);

//查询列数

//$query_cols = mysql_num_fields($query_res);

//查询行数

$query_num =mysql_num_rows($query_res);

//返回根据从结果集取得的行生成的数组,如果没有更多行

echo "table border='0' cellpadding='1' cellspacing='2' width='100%' bgcolor='#FFFFFF'";

while($query_row = mysql_fetch_array($query_res_sec)) {

echo "tr";

for ($i=0;$i$query_cols;$i++) {

echo "td bordercolor='#A2BEE1' bgcolor='#A2BEE1' width='8%'".$query_row[$i]."/tdn";

}

echo "td bordercolor='#A2BEE1' bgcolor='#A2BEE1' width='8%'";

//echo "input type='button' class='button' id='modify_record' name='modify_record' value='修改' /";

echo"button onClick="submit(location.href='../modify/modify.php?rec_id=$query_row[0]');"class="button";修改/button";

//echo "ahref='../delete/delete.php?rec_id=$query_row[0]'onClick="if(confirm('确实要删除此条记录吗?')) return true;else returnfalse;"img src="../image/delete.gif" align="absmiddle"/删除/a";

echo "buttononClick="if(confirm('确实要删除此条记录吗?')) return submit(location.href='../delete/delete.php?rec_id=$query_row[0]');else return false;"class="button";删除/button";

echo "/td";

echo "/tr";

}

//echo "/form";

echo "/table";

require_once("../common/subPages.php");//总条目数为数据库中查询出的数据条数

$nums=$query_num;

//每次显示的页数

$sub_pages=10; //if(!$pageCurrent) $pageCurrent=1;

//调用类SubPages 传的参数为:每页显示条数/当前第几页/每次显示的页数/分页模式

$subPage=new SubPages($page_size,$nums,$pageCurrent,$sub_pages,"query.php?p=",1);

}else{

die('数据库连接异常: '.mysql_error());

}

//断开数据库连接

if ($conn)

{

mysql_close($conn);

}

?

php分页功能怎么实现

php本身是没有分页概念的,分页是URL传参,然后通过mysql查询语句到数据库获取数据,然后实现的分页,url上的参数,通过PHP的$_GET都是可以获取到的。

现在市面上的PHP框架基本都有PHP分页类,参照文档直接调用就好了,如果想看实现过程,可以去下载一个TP框架,然后打开里面的分页类查看里面的源代码。

php分页代码 怎么写

 Web开发是今后分布式程式开发的主流,通常的web开发都要涉及到与数据库打交道,客户端从服务器端读取通常都是以分页的形式来显示,一页一页的阅读起来既方便又美观。所以说写分页程序是web开发的一个重要组成部分,在这里,我们共同来研究分页程序的编写。

一、分页程序的原理

分页程序有两个非常重要的参数:每页显示几条记录($pagesize)和当前是第几页($page)。有了这两个参数就可以很方便的写出分页程序,我们以MySql数据库作为数据源,在mysql里如果要想取出表内某段特定内容可以使用的 T-SQL语句:select * from table limit offset,rows来实现。这里的offset是记录偏移量,它的计算方法是offset=$pagesize*($page-1),rows是要显示的记录条数,这里就是$page。也就是说select * from table limit 10,10这条语句的意思是取出表里从第11条记录开始的20条记录。

二、主要代码解析

$pagesize=10; //设置每一页显示的记录数

$conn=mysql_connect("localhost","root",""); //连接数据库

$rs=mysql_query("select count(*) from tb_product",$conn); //取得记录总数$rs

$myrow = mysql_fetch_array($rs);

$numrows=$myrow[0];

//计算总页数

$pages=intval($numrows/$pagesize);

//判断页数设置

if (isset($_GET['page'])){

 $page=intval($_GET['page']);

}

else{

 $page=1; //否则,设置为第一页

}

三、创建用例用表myTable

create table myTable(id int NOT NULL auto_increment,news_title varchar(50),news_cont text,add_time datetime,PRIMARY KEY(id))

四、完整代码

<html>

<head>

<title>php分页示例</title>

<meta http-equiv="Content-Type" content="text/html; charset=gb2312">

</head>

<body>

<?php

 $conn=mysql_connect("localhost","root","");

 //设定每一页显示的记录数

 $pagesize=1;

 mysql_select_db("mydata",$conn);

 //取得记录总数$rs,计算总页数用

 $rs=mysql_query("select count(*) from tb_product",$conn);

 $myrow = mysql_fetch_array($rs);

 $numrows=$myrow[0];

 //计算总页数

 $pages=intval($numrows/$pagesize);

 if ($numrows%$pagesize)

$pages++;

 //设置页数

 if (isset($_GET['page'])){

$page=intval($_GET['page']);

 }

 else{

//设置为第一页

$page=1;

 }

 //计算记录偏移量

 $offset=$pagesize*($page - 1);

 //读取指定记录数

 $rs=mysql_query("select * from myTable order by id desc limit $offset,$pagesize",$conn);

 if ($myrow = mysql_fetch_array($rs))

 {

$i=0;

?>

<table border="0" width="80%">

<tr>

 <td width="50%" bgcolor="#E0E0E0">

<p align="center">标题</td>

<td width="50%" bgcolor="#E0E0E0">

<p align="center">发布时间</td>

</tr>

<?php

 do {

$i++;

?>

<tr>

 <td width="50%"><?=$myrow["news_title"]?></td>

 <td width="50%"><?=$myrow["news_cont"]?></td>

</tr>

 <?php

 }

 while ($myrow = mysql_fetch_array($rs));

echo "</table>";

}

echo "<div align='center'>共有".$pages."页(".$page."/".$pages.")";

for ($i=1;$i< $page;$i++)

 echo "<a href='fenye.php?page=".$i."'>[".$i ."]</a> ";

 echo "[".$page."]";

 for ($i=$page+1;$i<=$pages;$i++)

echo "<a href='fenye.php?page=".$i."'>[".$i ."]</a> ";

echo "</div>";

 ?>

</body>

</html>

五、总结

本例代码在windows2000 server+php4.4.0+mysql5.0.16上运行正常。该示例显示的分页格式是[1][2][3]…这样形式。假如想显示成“首页 上一页 下一页 尾页”这样形式,请加入以下代码:

$first=1;

$prev=$page-1;

$next=$page+1;

$last=$pages;

if ($page > 1)

{

 echo "<a href='fenye.php?page=".$first."'>首页</a> ";

 echo "<a href='fenye.php?page=".$prev."'>上一页</a> ";

}

if ($page < $pages)

{

 echo "<a href='fenye.php?page=".$next."'>下一页</a>

 echo "<a href='fenye.php?page=".$last."'>尾页</a> ";

}

其实,写分页显示代码是很简单的,只要掌握了它的工作原理。希望这篇文章能够带给那些需要这方面程序web程序员的帮助。

php 分页类怎么用啊?

?php

    class Page {

        private $total_rows;//数据库总条数

        private $per_page_rows;//每页显示条数

        private $limit;

        private $uri;

        private $total_pages;//总页数

        private $config=array("header"="记录条数","prev"="上一页","next"="下一页","first"="首 页","last"="尾 页");

        private $list_length=8;

        public function __construct($total_rows,$per_page_rows=10,$url_args){

            $this-total_rows=$total_rows;

            $this-per_page_rows=$per_page_rows;

            $this-uri=$this-get_uri($url_args);

            $this-page = !empty($_GET['page']) ? $_GET['page'] : 1;

            $this-total_pages=ceil($this-total_rows/$this-per_page_rows);

            $this-limit=$this-set_limit();

        }

        private function set_limit() {

            return "limit ".($this-page-1)*$this-per_page_rows.",{$this-per_page_rows}";

        }

        private function get_uri($url_args) {

            $url=$_SERVER["REQUEST_URI"].(strpos($_SERVER["REQUEST_URI"],"?") ? "" : "?").$url_args;

            $parse=parse_url($url);

            if (isset($parse['query'])) {

                parse_str($parse['query'],$params);//把url字符串解析为数组

                unset($params['page']);//删除数组下标为page的值

                $url=$parse['path'].'?'.http_build_query($params);//再次构建url

            }

                return $url;

        }

        public function __get($args) {

            if ($args=="limit") {

                return $this-limit;

            }else{

                return null;

            }

        }

        private function start_page(){

            if ($this-total_rows==0) {

                return 0;

            }else{

                return (($this-page-1)*$this-per_page_rows)+1;

            }

        }

        private function end_page(){

            return min($this-page*$this-per_page_rows,$this-total_rows);

        }

        private function go_first() {

            $html="";

            if ($this-page==1) {

                $html.="nbsp;{$this-config['first']}nbsp;";

            }else{

                $html.="nbsp;a href='{$this-uri}page=1'{$this-config['first']}/anbsp;";

            }

            return $html;

        }

        private function go_prev() {

            $html="";

            if ($this-page==1) {

                $html.="nbsp;{$this-config['prev']}nbsp;";

            }else{

                $html.="nbsp;a href='{$this-uri}page={$this-page}-1'{$this-config['prev']}/anbsp;";

            }

            return $html;

        }

        private function go_next() {

            $html="";

            if ($this-page==$this-total_pages) {

                $html.="nbsp;{$this-config['next']}nbsp;";

            }else{

                $html.="nbsp;a href='{$this-uri}page={$this-page}+1'{$this-config['next']}/anbsp;";

            }

            return $html;

        }

        private function go_last() {

            $html="";

            if ($this-page==$this-total_pages) {

                $html.="nbsp;{$this-config['last']}nbsp;";

            }else{

                $html.="nbsp;a href='{$this-uri}page={$this-total_pages}'{$this-config['last']}/anbsp;";

            }

            return $html;

        }

        private function go_page() {

            return 'nbsp;input type="text" onkeydown="javascript:if(event.keyCode==13){var page=(this.value'.$this-total_pages.')?'.$this-total_pages.':this.value;location=''.$this-uri.'page='+page+''}" value="'.$this-page.'" style="width:25px;" /input type="button" onclick="javascript:var page=(this.previousSibling.value'.$this-total_pages.')?'.$this-total_pages.':this.previousSibling.value;location=''.$this-uri.'page='+page+''" value="GO" /nbsp;';

        }

        private function page_list() {

            $link_page="";

            $i_num=floor($this-list_length/2);

            for ($i = $i_num; $i = 1; $i--) {

                $page=$this-page-$i;

                if ($page1) {

                    continue;

                }else{

                    $link_page.="nbsp;a href='{$this-uri}page={$page}'{$page}/anbsp;";

                }

            }

            $link_page.="nbsp;{$this-page}nbsp;";

            for ($i = 1; $i  $i_num; $i++) {

                $page=$this-page+$i;

                if ($page=$this-total_pages) {

                    $link_page.="nbsp;a href='{$this-uri}page={$page}'{$page}/anbsp;";

                }else{

                    break;

                }

            }

            return $link_page;

        }

        public function out_page($display=array(0,1,2,3,4,5,6,7,8)) {

            $display_html='';

            $html[0]="nbsp;共有b{$this-total_rows}/b{$this-config['header']}nbsp;";

            $html[1]="nbsp;每页显示b".($this-end_page()-$this-start_page()+1)."/b条,本页显示从b{$this-start_page()}/b--b{$this-end_page()}/b{$this-config['header']}nbsp;";

            $html[2]="nbsp;b{$this-page}/b/b{$this-total_pages}/b页nbsp;";

            $html[3]=$this-go_first();

            $html[4]=$this-go_prev();

            $html[5]=$this-page_list();

            $html[6]=$this-go_next();

            $html[7]=$this-go_last();

            $html[8]=$this-go_page();

            foreach ($display as $index){

                $display_html.=$html[$index];

            }

            return $display_html;

        }

    }

?

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。