php实现分页
php函数
<?php
//////////////////
//$result :容器的id
//$url:请求的url
//$total:总条数
//$num:页容量
//$pagenum:总页数
//$page:当前页
//$prepg:上一页
//$nextpg:下一页
//offset:limit后面的那个
////////////////
function ajaxPage($result,$url,$total,$num=20)
{
global $page,$pagenum,$prepg,$nextpg,$offset;
$GLOBALS["num"]=$num;
$page=isset($_GET['page'])?intval($_GET['page']):1; //这句就是获取page=18中的page的值,假如不存在page,那么页数就是1。
//$url='test1.php';//获取本页URL
$pagenum=ceil($total/$num); //获得总页数,也是最后一页
$page=min($pagenum,$page);//获得首页
$prepg=$page-1;//上一页
$nextpg=($page==$pagenum ? 0 : $page+1);//下一页
$offset=($page-1)*$num;
//开始分页导航条代码:
if($total==$offset+1){
$pagenav="显示第 <B>".$total."</B> 条记录,共 $total 条记录 ";
}else{
$pagenav="
显示第
<B>".($total?($offset+1):0)."</B>-<B>".min($offset+$num,$total)."</B>
条记录,共 $total 条记录 ";
}
//如果只有一页则跳出函数:
if($pagenum<1)
{
return false;
}
//获取url
if(strpos($url,"?")){
$firstPg =$url."&page=1";
$prePg = $url."&page=".$prepg;
$nextPg = $url."&page=".$nextpg;
$lastPg=$url."&page=".$pagenum;
}else{
$firstPg =$url."?page=1";
$prePg = $url."?page=".$prepg;
$nextPg = $url."?page=".$nextpg;
$lastPg=$url."?page=".$pagenum;
}
$pagenav.=" <a href=javascript:dopage('$result','$firstPg');>首页</a> ";
if($prepg) $pagenav.=" <a href=javascript:dopage('$result','$prePg');>上一页</a> "; else $pagenav.=" 上一页 ";
if($nextpg) $pagenav.=" <a href=javascript:dopage('$result','$nextPg');>下一页</a> "; else $pagenav.=" 下一页";
$pagenav.=" <a href=javascript:dopage('$result','$lastPg');>末页</a> ";
$pagenav.="</select> 页,共 $pagenum 页";
return $pagenav;
//假如传入的页数参数大于总页数,则显示错误信息
if($page>$pagenum){
Echo "Error : Can Not Found The page ".$page;
Exit;
}
//echo $num;
}
?>
把以上代码存为一个文件命名为ajaxPage.php
js代码
var http_request=false;
function send_request(url)
{
http_request=false;
//开始初始化XMLHttp对象
if(window.XMLHttpRequest){//MOILLA浏览器
http_request=new XMLHttpRequest();
if(http_request.overrideMimeType){
http_request.overrideMimeType("text/xml");
}
}
else if(window.ActiveXObject){//IE 浏览器
try{
http_request=new ActiveXObject("Msxml2.XMLHttp");
}catch(e){
try{
http_request=new ActiveXObject("Microsoft.XMLHttp");
}catch(e){}
}
}if(!http_request){
window.alert("创建XMLHttp对象失败");
return false;
}
http_request.onreadystatechange=processrequest;
//确定发送请求方式,URL,及是否同步执行下段代码
http_request.open("GET",url,true);
http_request.send(null);
}
//处理返回信息函数
function processrequest(){
//alert(reobj);
if(http_request.readyState==4){
if(http_request.status==200){
//alert(http_request.responseText);
document.getElementById(reobj).innerHTML=http_request.responseText;
//alert(http_request.responseText);
}else{
alert("您所请求的页面不正常");
}
}
}
function dopage(obj,url){
//alert(222);
document.getElementById(obj).innerHTML="正在读取数据.....";
reobj=obj;
send_request(url);
}
把以上代码存为一个文件命名为ajaxPage.js
调用:
//sql语句
$query1
= "select * from domainpay,alldomain where domainpay.domainId =
alldomain.domainId and UNIX_TIMESTAMP('{$startTime}') <=
UNIX_TIMESTAMP(payTime) and UNIX_TIMESTAMP(payTime) <=
UNIX_TIMESTAMP('{$endTime}') and status = 'active' and payTime is not
NULL";
}
//执行sql语句
$db -> execute($query);
//提取结果集
$result = $db -> fetch();
//计算总条数
$total = $db -> recordNum;
//分页函数的调用
$pagenav1
=
ajaxPage("supplement","isupplement.php?start={$_GET['start']}&end={$_GET['end']}&ac={$_GET['ac']}",$total,2);
$query.=" limit $offset,$num";
$db ->execute($query);
$result = $db -> fetch();
$db 是实例化的一个操作数据库的类!大家用的时候按照自己的即可!
php实现分页的更多相关文章
- 记一次SQLServer的分页优化兼谈谈使用Row_Number()分页存在的问题
最近有项目反应,在服务器CPU使用较高的时候,我们的事件查询页面非常的慢,查询几条记录竟然要4分钟甚至更长,而且在翻第二页的时候也是要这么多的时间,这肯定是不能接受的,也是让现场用SQLServerP ...
- js实现前端分页页码管理
用JS实现前端分页页码管理,可以很美观的区分页码显示(这也是参考大多数网站的分页页码展示),能够有很好的用户体验,这也是有业务需要就写了一下,还是新手,经验不足,欢迎指出批评! 首先先看效果图: 这是 ...
- JdbcTemplate+PageImpl实现多表分页查询
一.基础实体 @MappedSuperclass public abstract class AbsIdEntity implements Serializable { private static ...
- MVC如何使用开源分页插件shenniu.pager.js
最近比较忙,前期忙公司手机端接口项目,各种开发+调试+发布现在几乎上线无问题了:虽然公司项目忙不过在期间抽空做了两件个人觉得有意义的事情,一者使用aspnetcore开发了个人线上项目(要说线上其实只 ...
- NET Core-TagHelper实现分页标签
这里将要和大家分享的是学习总结使用TagHelper实现分页标签,之前分享过一篇使用HtmlHelper扩展了一个分页写法地址可以点击这里http://www.cnblogs.com/wangrudo ...
- 套用JQuery EasyUI列表显示数据、分页、查询
声明,本博客从csdn搬到cnblogs博客园了,以前的csdn不再更新,朋友们可以到这儿来找我的文章,更多的文章会发表,谢谢关注! 有时候闲的无聊,看到extjs那么肥大,真想把自己的项目改了,最近 ...
- php实现的分页类
php分页类文件: <?php /** file: page.class.php 完美分页类 Page */ class Page { private $total; //数据表中总记录数 pr ...
- C#关于分页显示
---<PS:本人菜鸟,大手子还请高台贵手> 以下是我今天在做分页时所遇到的一个分页显示问题,使用拼写SQL的方式写的,同类型可参考哦~ ------------------------- ...
- JAVA 分页工具类及其使用
Pager.java package pers.kangxu.datautils.common; import java.io.Serializable; import java.util.List; ...
- 分页插件--根据Bootstrap Paginator改写的js插件
刚刚出来实习,之前实习的公司有一个分页插件,和后端的数据字典约定好了的,基本上是看不到内部是怎么实现的,新公司是做WPF的,好像对于ASP.NET的东西不多,导师扔了一个小系统给我和另一个同事,指了两 ...
随机推荐
- HDU2050 由直线分割平面推广到折线分割平面
直线分割平面问题: 加入已有n-1条直线,那么再增加一条直线,最多增加多少个平面? 为了使增加的平面尽可能的多,我们应该使新增加的直线与前n条直线相交,且不存在公共交点.那么我们可以将新增加的这条直线 ...
- json的学习笔记
json比较简单,所以先从json开始学起. 一 json的名称: json的全称是javascript object notation,中文名称为js 对象表示法. json的定义:json是一种轻 ...
- 2014 Shanghai Invitation Contest
题目链接 http://acm.hdu.edu.cn/search.php?field=problem&key=2014%C9%CF%BA%A3%C8%AB%B9%FA%D1%FB%C7%EB ...
- 事务(JDBC、Hibernate、Spring)
如果不用spring管理事务,我们自己写代码来操作事务.那么这个代码怎么写要看底层怎么访问数据库了. 当采用原生JDBC访问数据库时,操作事务需要使用java.sql.Connection的API.开 ...
- iOS屏幕旋转 浅析
一.两种orientation 了解屏幕旋转首先需要区分两种orientation 1.device orientation 设备的物理方向,由类型UIDeviceOrientation表示,当前设备 ...
- Linux学习 -- Shell编程 -- 流程控制
if语句 单分支 if [ 条件判断式 ]; then 程序 fi 或者 if [ 条件判断式 ] then 程序 fi 例子: 双分支 if [ 条件判断式 ] then 程序 else 程序 fi ...
- 如何在使用eclipse的情况下,清理android项目中的冗余class文件和资源文件以及冗余图片
在我们迭代项目的过程中,经常会启用某些功能,或者修改某些界面的问题,那么问题来了,这样很容易出现大量的冗余.java文件,冗余资源文件,一些冗余的界面文件等.那么问题既然出现了,那么如何去解决呢,这就 ...
- angularjs中动态为audio绑定src
今天在angularjs中用audio的时候碰到的这些问题,查阅http://www.cnblogs.com/rachelanlan/p/3598070.html获得解决,感谢! <div cl ...
- JSP内置对象--session对象(getId(),getCreationTime(),getLastAccessedTime(),isNew(),invalidate(),setAttribute(),getAttribute())
session对象是javax.servlet.http.HttpSession接口的实例,但是不像HttpServletRequest或HttpServletResponse一样,有父接口,他没有父 ...
- CF 672 div2 D
http://codeforces.com/contest/672/problem/D 题目大意: 有n个人,每个人有pi的钱,然后可以由如下操作,每次都可以挑选一个最富有的人,把它的钱给最穷的人.但 ...