php实现仿百度分页

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了php实现仿百度分页相关的知识,希望对你有一定的参考价值。

本文主要和大家分享php实现仿百度分页的实例,先来看一下效果图。

 

基本策略

1, 首先要查询总记录数

2, 设置每页显示的数量并计算总页数

3, 增加一个get传值num代表当前访问的是哪一页,如果没有num的get传值,应该设置默认的当前页为第一页!

4, 就拿一个字符串来保存页码链接,这个字符串也叫作页码字符串!

5, 在查询的时候,就应该使用limit子句进行限制(limit子句分页原理)

完成仿百度分页功能

分页需求

1, 当前页是前3页的时候,显示的初始页$startNum是1,显示的最后一页$endNum是5

2, 当前页是第4页的时候,$startNum为2,$endNum = $startNum +4, 当前页是第5页的时候,$startNum为3,依次类推

3, 页码的起始位置不能超过总页数 $pages – 4;

代码如下:

代码

//应该加载视图文件之前和提取帖子的结果集之前进行分页

//以下的代码都和分页相关

//(1)定义当前选中的页码数

$pageNum = isset($_GET[\'num\'])?$_GET[\'num\']: 1;

//(2)定义每一页显示的记录数

$rowsPerPage = 5;

//(3)查询总记录

$sql="select count(*) as sum frompublish";

$result = my_query($sql);

$row = mysql_fetch_assoc($result);

$rowCount = $row[\'sum\'];//得到总记录数

//(4)计算总页数

$pages = ceil($rowCount/$rowsPerPage);//得到总页数

//(5)拼凑页码字符串

$strPage = \'\';//页码字符串

//拼凑出首页

$strPage .= "<ahref=\'./list_father.php?num=1\'>首页</a>";

//拼凑出上一页

$preNum = $pageNum == 1 ? 1 : $pageNum-1;

$strPage .= "<ahref=\'./list_father.php?num=$preNum\'>上一页</a>";

  

//确定显示的初始页$startNum

if($pageNum<=3){

         $startNum= 1;

}else{

         $startNum= $pageNum - 2;

}

//确定显示的初始页$startNum的最大值

if($startNum > $pages- 4){

         $startNum= $pages-4;

}

//防止页码出现复制

if($startNum<=1){

         $startNum=1;

}

//确定显示的最后一页 $endNum

$endNum=$startNum+4;

//防止最后一页越界;

if($endNum>=$pages){

         //$endNum=$pageNum;//错误

         $endNum=$pages;

}

//拼凑出中间的页码

for($i=$startNum;$i<=$endNum;$i++){

         //如果$i刚好是选中的当前页,标红

         if($i==$pageNum){

                   $strPage.= "<a href=\'./list_father.php?num=$i\'><fontcolor=\'red\'>$i</font></a>";

         }else{

                   $strPage.= "<a href=\'./list_father.php?num=$i\'>$i</a>";

         }

         //$strPage.= "<a href=\'./list_father.php?num=$i\'>$i</a>";

  

         

}

/*for($i=1;$i<=$pages;$i++){

         $strPage.= "<a href=\'./list_father.php?num=$i\'>$i</a>";

}*/

  

  

////拼凑出下一页

$nextNum = $pageNum == $pages ? $pages :$pageNum+1;

$strPage .= "<a href=\'./list_father.php?num=$nextNum\'>下一页</a>";

//拼凑出尾页

$strPage .= "<ahref=\'./list_father.php?num=$pages\'>尾页</a>";

  

//提取帖子的结果集

$offset = $rowsPerPage*($pageNum-1);

$sql="select * from publish left joinuser on pub_owner=user_name order by pub_time desc limit$offset,$rowsPerPage";

$result=my_query($sql);//得到了资源结果集

 

以上是关于php实现仿百度分页的主要内容,如果未能解决你的问题,请参考以下文章

php分页例子实现读取mysql数据分页显示

php分页原理,懂得的指教一下哈!

案例如何用jquery实现仿百度新闻焦点图

仿百度壁纸client——实现搜索动画GestureDetector手势识别,动态更新搜索keyword

仿百度壁纸client——完结篇之Gallery画廊实现壁纸预览已经项目细节优化

(进阶篇)jQuery+Ajax+PHP+Mysql实现分页显示数据