<?php
 /**
  * @desc created by sublime text3
  * @author jxl <[57953279@qq.com>]>
  * @since 2017/05/06 23:06
  */
 $host="localhost";
 $user='root';
 $pass='';
 $link=mysql_connect($host,$user,$pass) or die('数据库连接失败');
 mysql_select_db('demo');
 mysql_query('set names "utf8"');

 $pageSize=10;//每页5条
 $bothNum=4;//当前页左右各显示4个页码
 $cur_page=isset($_GET['cur_page'])?$_GET['cur_page']:1;//当前页数

 $sql="select * from test_db";
 $res=mysql_query($sql);
 $total=mysql_num_rows($res);//总记录数
 $pageNum=ceil($total/$pageSize);//总页数

 $start=($cur_page-1)*$pageSize;
 $sql="select * from test_db limit $start,$pageSize";
 $res=mysql_query($sql);
 while ($row=mysql_fetch_array($res)) {
     echo $row['id'].'---'.$row['name'].'---'.$row['age'];
     echo '<hr/>';
 }

 //上一页
 $pagestr="";
 if($cur_page==1){
     $pagestr.='<span>上一页</span>';
 }else{
     $lastPage=$cur_page-1;
     $pagestr.="<a href='mysqldemo.php?cur_page=$lastPage'>上一页</a>"."  ";
 }
 // 想象分页如下,目前第 10 页,它两边最多只有 4 (bothnum) 个数字
 // 1 ...  6 7 8 9 *10* 11 12 13 14 15 ... 100
 // echo $pagestr;
 // 首页
 if($cur_page-$bothNum>1){
     $pagestr.="<a href='mysqldemo.php?cur_page=1'>首页</a>";
     $pagestr.="<span>...</span>";
 }
 //当前页的左边
 for($i=$bothNum;$i>=1;$i--){
     if(($cur_page - $i) < 1 ) { // 当前页左边花最多 bothnum 个数字
          continue;
      }
     $lastPage=$cur_page-$i;
     $pagestr.="<a href='mysqldemo.php?cur_page=$lastPage'>$lastPage</a>"."  ";
 }
 //当前页
 $pagestr.="<span>$cur_page</span>"."  ";
 //当前页右边
 for($i=1;$i<=$bothNum;$i++){
     if(($cur_page + $i) > $pageNum) { // 当前页右边最多 bothnum 个数字
         break;
     }
     $lastPage=$cur_page+$i;
     $pagestr.="<a href='mysqldemo.php?cur_page=$lastPage'>$lastPage</a>"."  ";

 }

 //尾页
 if(($cur_page+$bothNum)<$pageNum){
     $pagestr.="<span>...</span>"."  ";
     $pagestr .= '<a href="?cur_page='.$pageNum.'">尾页</a>'."  ";
 }
 //下一页
  if($cur_page == $pageNum) {
        $pagestr .= '<span>下一页</span>';
    } else {
           $nextPage=$cur_page+1;
        $pagestr .= "<a href='mysqldemo.php?cur_page={$nextPage}'>下一页</a>";
    }
 echo $pagestr;
 echo "<hr/>";
 echo '当前页数为:'.$cur_page.',总页数为:'.$pageNum; 

PHP简单分页省略中间页码的更多相关文章

  1. JavaScript简单分页,兼容IE6,~3KB

    简介 兼容IE6+及现代浏览器的简单分页,支持同一页面多个分页. 使用 Browser <link rel="stylesheet" href="css/GB-pa ...

  2. vue.js 2.0实现的简单分页

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8" /> <title&g ...

  3. 通过 Django Pagination 实现简单分页

    作者:HelloGitHub-追梦人物 文中所涉及的示例代码,已同步更新到 HelloGitHub-Team 仓库 当博客上发布的文章越来越多时,通常需要进行分页显示,以免所有的文章都堆积在一个页面, ...

  4. MVC简单分页

    对Car汽车表分页 实现简单分页,放在这里方便查看回顾,自定义每页几条有点问题,有待完善······ 1.新建mvc项目 2.添加linq to sql 数据库连接 3.添加CarBF类 using ...

  5. 使用Vs2005打造简单分页浏览器(1)原创

    原文:使用Vs2005打造简单分页浏览器(1)原创 使用Vs2005打造简单分页浏览器(1)原创1引言2功能3实现过程以及关键点4总结5不足之处6其他7 代码下载 1    引言很早就有搞一个浏览器的 ...

  6. MVC001之mvcpager简单分页

    描述:用mvcpager实现简单分页功能 参考网址: http://www.cnblogs.com/iamlilinfeng/archive/2013/03/11/2951460.html http: ...

  7. ASP.NET MVC 简单分页代码

    using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.We ...

  8. mysql大数据量使用limit分页,随着页码的增大,查询效率越低下

    1.   直接用limit start, count分页语句, 也是我程序中用的方法: select * from product limit start, count当起始页较小时,查询没有性能问题 ...

  9. Asp.net MVC 简单分页 自做简单分页

    Asp.net MVC 简单分页:   public static string Pager(int page,int pageSize,int total)         {           ...

随机推荐

  1. ngrok完成内网映射外网

    项目需求: 完成微信公众号开发配置搭建,其中需要一个可以外部访问的域名 实现技术: www.ngrok.cc 实现方式: 在该网站最下方下载需要的ngrok文件,在最上方点击注册,获取token,之后 ...

  2. 关于ng的路由的几点想法(ui-view)

    在配置路由的时候,我们可以选择ng框架自带的路由,也可以使用第三方路由插件ui-router 注意: (1)在使用angular-ui-router的时候,必须先引入angular-ui-router ...

  3. Linux云自动化运维第八课

    第十三单元 软件安装 一.软件名称识别 [abrt-addon-ccpp]-[2.1.11-19].[el7].[x86_64].rpm ###rpm结尾的适用与redhat操作系统 ||       ...

  4. Java集合总结系列2:Collection接口

    Collection 接口是 Java 集合类的一个根接口,Java 在 Collection 接口中定义了许多通用的数据操作类方法以及判断类方法. 通过查看 API 文档或源码的方式,我们可以了解到 ...

  5. Hexo + Github Pages 搭建个人博客

    之前一直想搭建自己的博客,由于自己的懒惰拖到现在.好了,废话不多说!直接上干货! 安装Node.js 安装Git Github Pages配置 安装Hexo及主题设置 进阶篇-高级定制 其它实用功能 ...

  6. 深度学习实践系列(3)- 使用Keras搭建notMNIST的神经网络

    前期回顾: 深度学习实践系列(1)- 从零搭建notMNIST逻辑回归模型 深度学习实践系列(2)- 搭建notMNIST的深度神经网络 在第二篇系列中,我们使用了TensorFlow搭建了第一个深度 ...

  7. Vuex随笔

    最近在项目中使用到了vuex,但是在配合vue使用时,也还是遇到了不少的问题,最终还是解决了问题,因此写一篇随笔来记录期间遇到的问题吧 项目概要: Vuex中所储存的的状态如下: Vue中:有一个ta ...

  8. Ant Design 的一个练习小Demo

    Ant Design 由蚂蚁金服团队出品, 基于 React 的组件化开发模式,封装了一套丰富而实用的 UI 组件库. 在这个练习Demo 中,按照 Ant Design 官网的教程示例,尝试使用 A ...

  9. C#变量、常量、枚举、预处理器指令知多少

    一.变量 C#共有其中变量类型有:静态变量.实类变量.数组元素.数值参数.引用参数.输出参数和局部变量 先定义一个简单的类来说明,如下: public class VariableDefine { p ...

  10. 通过web对.exe程序进行更新和修改

    实现功能:通过网站更新用户的软件,需要联网,也可以通过本地网站更新局域网用户软件. 根本实现:1.一个网站(我用的是自己的www.aq36.xyz ,本地就可以,可以用localhost)然后运行up ...