本文主要和大家分享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实现仿百度分页的更多相关文章

  1. JAVA仿百度分页

    最近在做一个仿百度网盘的网页小应用,找到了一个优雅简洁的分页插件,和百度搜索的分页很相似,对他进行了二次封装,拿出来跟大家分享下 插件源码 /** * This jQuery plugin displ ...

  2. 自定义vue组件之仿百度分页逻辑

    <template> <div> <ul :total="total" :pageSize="pageSize" :pageNum ...

  3. 仿百度糯米TP5项目笔记

    需求分析 系统三大模块 商家平台.主平台.前台模块 Thinkphp5.0实战 仿百度糯米开发多商家电商平台网盘下载 (2017-04-24 01:46:23) 转载▼     第1章 课程简介 本章 ...

  4. WPF仿百度Echarts人口迁移图

    GitHub地址:https://github.com/ptddqr/wpf-echarts-map/tree/master 关于大名鼎鼎的百度Echarts我就不多说了 不了解的朋友直接看官方的例子 ...

  5. 【原创】jQuery 仿百度输入标签插件

    1.先上效果图 2.调用方式 <link href="/Styles/tagsinput.css" rel="stylesheet" type=" ...

  6. ArcGIS JS 学习笔记2 实现仿百度的拖拽画圆

    一.前言 吐槽一下,百度在国内除了百度地图是良心产品外,其他的真的不敢恭维.在上一篇笔记里,我已经实现了自定义的地图测量模块.在百度地图里面(其他地图)都有一个周边搜索的功能,拖拽画一个圆,然后以圆半 ...

  7. 一款基于jQuery的仿百度首页滑动选项卡

    今天给大家分享一款基于jQuery的仿百度首页滑动选项卡.这款选项卡适用浏览器:IE8.360.FireFox.Chrome.Safari.Opera.傲游.搜狗.世界之窗.效果图如下: 在线预览   ...

  8. 高仿百度传课应用客户端源码iOS版

    高仿百度传课iOS版,版本号:2.4.1.2 运行环境:xcode6.3  ios8.3 (再往上系统没有测试) 转载请注明出处,不可用于商业用途及不合法用途. 如果你觉得不错,欢迎  star  哦 ...

  9. iOS-Andriod百度地图仿百度外卖-饿了么-选择我的地址-POI检索/

    http://zanderzhang.gitcafe.io/2015/09/19/iOS-Andriod百度地图仿百度外卖-饿了么-选择我的地址-POI检索/ 百度外卖选择送货地址: 饿了么选择送货地 ...

随机推荐

  1. 观察者模式的python实现

    什么会观察者模式?观察者模式就是订阅-推送模式.是为了解耦合才会被利用起来的设计模式. 经典的就是boss 前台和员工之间的故事.一天A员工在看电影,B员工在看动漫,但是两人担心boss来了,自己没及 ...

  2. xpath, urllib

    li_category = response.xpath("//div[@class='r-name']") <div class="r-name"> ...

  3. Json解析注解 ---@SerializedName

    项目前后端交互采用的是JSON传输,因为前后端沟通不多,经常造成数据格式不统一:在不想后台改动太多下,需要使用@SerializedName解决这个问题 解析数据使用的是Gson解析的json数据 @ ...

  4. LeetCode 147. Insertion Sort List 链表插入排序 C++/Java

    Sort a linked list using insertion sort. A graphical example of insertion sort. The partial sorted l ...

  5. java和.net连接数据库的方法

    .net连接数据库的方法 App.config <connectionStrings> <add name="" connectionString="D ...

  6. sql 日志文件截断收缩

    use mydb ALTER DATABASE mydb SET RECOVERY SIMPLE WITH NO_WAIT ALTER DATABASE mydb SET RECOVERY SIMPL ...

  7. Python re.findall函数不能匹配但是notepad++能匹配

    我使用同样的表达式匹配同样的网页源码,在notepad++里面不能直接使用,需要将内容都弄到同一行中. 但是我使用 requests.get(self.url).content.decode('UTF ...

  8. Unable to connect to MKS;Too many scoket connect attempts;giving up

    Unable to connect to MKS;Too many scoket connect attempts;giving up(无法连接到MKS;太多scoket连接尝试;放弃) 第一次学习虚 ...

  9. 前端面试之Javascript

    1,JS基本的数据类型和引用类型: (1)基本数据类型:number,string,null,undefined,symbol--栈: (2)引用数据类型:object,array,function- ...

  10. Django中的auth模块

    from django.contrib import auth authenticate() 提供了用户认证功能,即验证用户名以及密码是否正确,一般需要username .password两个关键字参 ...