php分页示例代码


Posted in PHP onMarch 19, 2007

<?php 
/* 
需求,建立一个test数据库,在里边建一个test表,里面就 
只要id字段,输入一下数据就可以啦。。 
由于水平有限,难免出错。。 
*/ 
$conn = mysql_connect("localhost","root",""); 
$maxnum = 2;  //每页显示记录条数 
mysql_select_db("test", $conn); 
$query1 = "SELECT COUNT(*) AS totalrows FROM test "; 
$result1 = mysql_query($query1, $conn) or die(mysql_error()); 
$row1 = mysql_fetch_assoc($result1); 
$totalRows1 = $row1['totalrows'];  //数据集数据总条数 
$totalpages = ceil($totalRows1/$maxnum);//计算可分页总数,ceil()为上舍函数 
if(!isset($_GET['page']) || !intval($_GET['page']) || $_GET['page'] > $totalpages) $page = 1;  //对3种出错进行默认处理 
//在url参数page不存在时,page不为10进制数时,page大于可分页数时,默认为1 
else $page = $_GET['page']; 
$startnum = ($page - 1)*$maxnum; //从数据集第$startnum条开始取,注意数据集是从0开始的 
$query = "SELECT * FROM test LIMIT $startnum,$maxnum";//选择出符合要求的数据 从$startnum条数据开始,选出$maxnum行 
$result = mysql_query($query, $conn) or die(mysql_error()); 
$row = mysql_fetch_assoc($result); 
?> 
<html> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
<title>分页示例</title> 
<script language="JavaScript" type="text/JavaScript"> 
<!-- 
function MM_jumpMenu(targ,selObj,restore){ //v3.0 
  eval(targ+".location='"+selObj.options[selObj.selectedIndex].value+"'"); 
  if (restore) selObj.selectedIndex=0; 

//--> 
</script> 
<style type="text/css"> 
a{text-decoration:none;} 
a:hover{text-decoration:underline} 
table{font-size:12px;} 
.tb{background-color:#73BB95} 
.tr{background-color:#FFFFFF} 
</style> 
</head> 
<body> 
<table width="30%"  border="0" align="center" cellpadding="0" cellspacing="1" class="tb"> 
  <tr> 
    <td height="24"><div align="left">分页示例</div></td> 
  </tr> 
  <?php if($totalRows1) {//记录集不为空显示 
  do {  
  ?> 
  <tr class="tr"> 
    <td height="24"><div align="center"><?php echo $row['id'];?></div></td> 
  </tr> 
  <?php }while($row = mysql_fetch_assoc($result));?> 
</table> 
<table width="95%"  border="0" align="center" cellpadding="0" cellspacing="0"> 
  <tr><form name="form1"> 
    <td height="27"><div align="center"> 
    <?php  
     echo "共计<font color="#ff0000">$totalRows1</font>条记录"; 
     echo "<font color="#ff0000">".$page."</font>"."/".$totalpages."页 ";  
    //实现 << < 1 2 3 4 5> >> 分页链接 
    $pre = $page - 1;//上一页 
    $next = $page + 1;//下一页 
    $maxpages = 4;//处理分页时 << < 1 2 3 4 > >>显示4页 
    $pagepre = 1;//如果当前页面是4,还要显示前$pagepre页,如<< < 3 /4/ 5 6 > >> 把第3页显示出来 
    if($page != 1) { echo "<a href='".$_SERVER['PHP_SELF']."'><<</a> "; 
    echo "<a href='".$_SERVER['PHP_SELF'].'?page='.$pre."'><</a> ";} 
    if($maxpages>=$totalpages) //如果总记录不足以显示4页 
    {$pgstart = 1;$pgend = $totalpages;}//就不所以的页面打印处理 
    elseif(($page-$pagepre-1+$maxpages)>$totalpages)//就好像总页数是6,当前是5,则要把之前的3 4 显示出来,而不仅仅是4 
    {$pgstart = $totalpages - $maxpages + 1;$pgend = $totalpages;} 
    else{ 
    $pgstart=(($page<=$pagepre)?1:($page-$pagepre));//当前页面是1时,只会是1 2 3 4 > >>而不会是 0 1 2 3 > >> 
    $pgend=(($pgstart==1)?$maxpages:($pgstart+$maxpages-1)); 
    } 
    for($pg=$pgstart;$pg<=$pgend;$pg++){ //跳转菜单 
    if($pg == $page) echo "<a href="".$_SERVER['PHP_SELF']."?page=$pg"><font color="#ff0000">$pg</font></a> "; 
    else echo "<a href="".$_SERVER['PHP_SELF']."?page=$pg">$pg</a> "; 
    } 
    if($page != $totalpages) 
    {echo "<a href='".$_SERVER['PHP_SELF'].'?page='.$next."'>></a> "; 
    echo "<a href='".$_SERVER['PHP_SELF'].'?page='.$totalpages."'>>></a> ";} 
    ?> 
      <select name="menu1" onChange="MM_jumpMenu('parent',this,0)"> 
      <option value="">选择</option> 
      <?php for($pg1=1;$pg1<=$totalpages;$pg1++) { 
       echo "<option value="".$_SERVER['PHP_SELF']."?page=$pg1">".$pg1."</option>"; 
      }?> 
      </select> 
    </td></form> 
  </tr> 
</table> 
<?php } else {//记录集为空时显示?> 
<tr class="tr"> 
    <td height="24"><div align="center">没有任何记录</div></td> 
  </tr> 
  </table> 
<?php }?> 
</body> 
</html> 
<?php  
mysql_free_result($result1); 
mysql_free_result($result); 
?> 

PHP 相关文章推荐
apache+php+mysql安装配置方法小结
Aug 01 PHP
ajax php传递和接收变量实现思路及代码
Dec 19 PHP
php异步多线程swoole用法实例
Nov 14 PHP
PHP使用xmllint命令处理xml与html的方法
Dec 15 PHP
PHP多线程编程之管道通信实例分析
Mar 07 PHP
php制作文本式留言板
Mar 18 PHP
PHP的pcntl多进程用法实例
Mar 19 PHP
深入浅析php json 格式控制
Dec 24 PHP
php实现有序数组打印或排序的方法【附Python、C及Go语言实现代码】
Nov 10 PHP
php微信公众平台示例代码分析(二)
Dec 06 PHP
PHP 记录访客的浏览信息方法
Jan 29 PHP
PHP tp5中使用原生sql查询代码实例
Oct 28 PHP
简单介绍下 PHP5 中引入的 MYSQLI的用途
Mar 19 #PHP
IIS6的PHP最佳配置方法
Mar 19 #PHP
php中的实现trim函数代码
Mar 19 #PHP
php中判断一个字符串包含另一个字符串的方法
Mar 19 #PHP
php之字符串变相相减的代码
Mar 19 #PHP
PHP入门速成教程
Mar 19 #PHP
phpMyAdmin 安装教程全攻略
Mar 19 #PHP
You might like
PHP 和 MySQL 基础教程(四)
2006/10/09 PHP
PHP 类相关函数的使用详解
2013/05/10 PHP
基于PHP常用字符串的总结(待续)
2013/06/07 PHP
Laravel框架下载,安装及路由操作图文详解
2019/12/04 PHP
农历与西历对照
2006/09/06 Javascript
javascript hashtable 修正版 下载
2010/12/30 Javascript
JS字符串处理实例代码
2013/08/05 Javascript
原生js实现淘宝首页点击按钮缓慢回到顶部效果
2014/04/06 Javascript
js实现键盘控制DIV移动的方法
2015/01/10 Javascript
jQuery及JS实现循环中暂停的方法
2015/02/02 Javascript
javascript去掉代码里面的注释
2015/07/24 Javascript
javascript自动恢复文本框点击清除后的默认文本
2016/01/12 Javascript
Angularjs自定义指令实现三级联动 选择地理位置
2017/02/13 Javascript
详解vue表单验证组件 v-verify-plugin
2017/04/19 Javascript
浅谈React Native 中组件的生命周期
2017/09/08 Javascript
详解Vue组件实现tips的总结
2017/11/01 Javascript
JavaScript实现星级评价效果
2019/05/17 Javascript
[02:31]DOTA2帕克 英雄基础教程
2013/11/26 DOTA
Django如何实现内容缓存示例详解
2017/09/24 Python
使用pandas将numpy中的数组数据保存到csv文件的方法
2018/06/14 Python
django2+uwsgi+nginx上线部署到服务器Ubuntu16.04
2018/06/26 Python
Win10下python 2.7.13 安装配置方法图文教程
2018/09/18 Python
Python爬虫之UserAgent的使用实例
2019/02/21 Python
python3+PyQt5 实现Rich文本的行编辑方法
2019/06/17 Python
python二分法查找算法实现方法【递归与非递归】
2019/12/06 Python
Python脚本如何在bilibili中查找弹幕发送者
2020/06/04 Python
Python使用pickle进行序列化和反序列化的示例代码
2020/09/22 Python
德国大型的家具商店:Pharao24.de
2016/10/02 全球购物
委托证明模板
2014/09/16 职场文书
缓刑人员思想汇报
2014/10/11 职场文书
2014年残疾人工作总结
2014/12/06 职场文书
2015年幼儿园保育员工作总结
2015/04/23 职场文书
素质拓展训练感想
2015/08/07 职场文书
采购员工作总结范文
2015/08/12 职场文书
恶魔之树最顶端的三颗果实 震震果实上榜,第一可以制造岩浆
2022/03/18 日漫
Python实现双向链表基本操作
2022/05/25 Python