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 相关文章推荐
PHP与javascript的两种交互方式
Oct 09 PHP
编写漂亮的代码 - 将后台程序与前端程序分开
Apr 23 PHP
使用Apache的htaccess防止图片被盗链的解决方法
Apr 27 PHP
PHP中使用smarty生成静态文件的例子
Apr 24 PHP
Discuz7.2版的faq.php SQL注入漏洞分析
Aug 06 PHP
php向js函数传参的几种方法
Aug 10 PHP
PHP动态输出JavaScript代码实例
Feb 12 PHP
关于PHP文件的自动运行方法分析
May 13 PHP
php并发加锁示例
Oct 17 PHP
Yii2单元测试用法示例
Nov 12 PHP
php从数据库中读取特定的行(实例)
Jun 02 PHP
PHP中通过getopt解析GNU C风格命令行选项
Nov 18 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
基于Linux调试工具strace与gdb的常用命令总结
2013/06/03 PHP
php实现处理输入转义字符的代码
2015/11/08 PHP
PHP使用redis实现统计缓存mysql压力的方法
2015/11/14 PHP
php的api数据接口书写实例(推荐)
2016/09/22 PHP
浅谈PHP SHA1withRSA加密生成签名及验签
2019/03/18 PHP
用javascript实现计算两个日期的间隔天数
2007/08/14 Javascript
获取客户端电脑日期时间js代码(jquery)
2012/09/12 Javascript
文字不间断滚动(上下左右)实例代码
2013/04/21 Javascript
简单的jquery左侧导航栏和页面选中效果
2014/08/21 Javascript
js单独获取一个checkbox看其是否被选中
2014/09/22 Javascript
js实现select跳转功能代码
2014/10/22 Javascript
谈谈JavaScript异步函数发展历程
2015/09/29 Javascript
JavaScript中利用for循环遍历数组
2017/01/15 Javascript
js 获取今天以及过去日期
2017/04/11 Javascript
ionic App问题总结系列之ionic点击系统返回键退出App
2017/08/19 Javascript
详解vue 单页应用(spa)前端路由实现原理
2018/04/04 Javascript
AngularJS实现的鼠标拖动画矩形框示例【可兼容IE8】
2019/05/17 Javascript
vue中 this.$set的用法详解
2019/09/06 Javascript
vue组件中传值EventBus的使用及注意事项说明
2020/11/16 Javascript
linux系统使用python监测网络接口获取网络的输入输出
2014/01/15 Python
Python3.4编程实现简单抓取爬虫功能示例
2017/09/14 Python
python进行文件对比的方法
2018/12/24 Python
python中tkinter窗口位置\坐标\大小等实现示例
2020/07/09 Python
python“静态”变量、实例变量与本地变量的声明示例
2020/11/13 Python
Skyscanner阿联酋:全球领先的旅游搜索平台
2017/11/25 全球购物
Toppik顶丰增发纤维官网:解决头发稀疏
2017/12/30 全球购物
英国赛车、汽车改装和摩托车零件购物网站:Demon Tweeks
2018/10/29 全球购物
2013年高中生自我评价
2013/10/23 职场文书
合伙经营协议书范本
2014/04/18 职场文书
医院护士党的群众路线教育实践活动对照检查材料思想汇报
2014/10/04 职场文书
社区党员干部承诺书
2015/05/04 职场文书
幼儿园庆六一主持词
2015/06/30 职场文书
保护环境建议书作文300字
2015/09/14 职场文书
《水上飞机》教学反思
2016/02/20 职场文书
详解TypeScript的基础类型
2022/02/18 Javascript
配置Kubernetes外网访问集群
2022/03/31 Servers