效果链接http://love.bjxxw.com/oejiaoyou/pubu/zhaopian.php

php 分页

<?php
/* *
*
* 说明 吉海波 2015/9/17
* $pageSize=6;//每页显示
$page=$_GET['page'];//接收当前页
* //接收不到,就是第1页
if($page==""){
$page=1;
}
$showPage=5;//分页条中间 显示几个页的按钮
//得到数据总数
$total_sql="SELECT COUNT(*) FROM `oepre_user_photo`";
$total_result=mysql_fetch_array(mysql_query($total_sql));
$total= $total_result[0];
* $page_type是按钮样式 颜色有:皇军蓝色.blue,深天蓝色.DeepSkyBlue,粉色.pink ,灰色.gray,白色.white
* $page_type是按钮样式 类型有:圆形边框.rborder ,灰色边框.cborder,无边框.noborder,阴影边框3灰.shborder3,阴影边框2.shborder2,阴影边框1.shborder1,
* 调用方法 <?php fenye($pageSize,$page,$showPage,$total,"blue rborder cborder shborder2") ?>
* */
function fenye($pageSize,$page,$showPage,$total,$page_type){
//计算页数总数
$total_pages=ceil($total/$pageSize);
//分页条使用初始化
$page_banner="";
//计算偏移量
$pageoffset=($showPage-1)/2;
//初始化数据
$start=1;
$end=$total_pages;
//判断页码了
//没有这页
if($page > $total_pages || $page < 1 ){
echo '
<script>
alert("没有这页哦"); history.back();
</script>';
}
//首页,上一页
if( $page > 1){
$page_banner= "<a href=".$_SERVER['PHP_SELF']."?page=1>首页</a>";
$page_banner.= "<a href=".$_SERVER['PHP_SELF']."?page=".($page-1).">上一页</a>";
} if($total_pages>$showPage){
//首部省略号
if($page > $pageoffset + 1){
$page_banner.="...";
}
//思维区
if($page>$pageoffset){
$start=$page - $pageoffset;
$end=$total_pages > $page + $pageoffset ? $page + $pageoffset : $total_pages;
}else{
$start=1;
$end=$total_pages > $showPage ? $showPage : $total_pages;
}
if($page + $pageoffset > $total_pages){
$start=$start - ($page + $pageoffset - $end);
}
}
//中间页数按钮
for($j = $start; $j <= $end; $j++){
//当前页按钮样式
if($page == $j){
$page_banner.="<span class='visit_page middle_page'>{$j}</span>";
}else{
$page_banner.= "<a class='middle_page' href=".$_SERVER['PHP_SELF']."?page=".($j).">{$j}</a>";
}
}
//尾部省略号
if($total_pages > $showPage && $total_pages > $page + $pageoffset){
$page_banner.="...";
}
//尾页,下一页
if($page < $total_pages){
$page_banner.= "<a href=".$_SERVER['PHP_SELF']."?page=".($page+1).">下一页</a>";
$page_banner.="<a href=".$_SERVER['PHP_SELF']."?page=".($total_pages).">尾页</a>";
}
//总共页数
$page_banner.="<span class='all_page' >共<span id='all_page'>{$total_pages}</span>页</span>";
//页面跳转
$page_banner.='<form action="" method="get" class="page_form" name="page_form">';
$page_banner.='到第<input type="text" value="'.($page+1).'" name="page" id="page_value" oninput="page_on()" onpropertychange="page_on()">';
$page_banner.='<input type="submit" value="确定" class="page_sure" name="page_sure" id="page_sure">';
$page_banner.='</form>'; //输出页码条
echo "<span class='".$page_type." type_fix'>".$page_banner."</span>";
//最后一页
if($page == $total_pages){
echo '
<script>
document.getElementById("page_value").value="1";
</script>';
}
//检测跳转页码是否乱输入
echo '
<script>
function page_on(){
var page_value=document.getElementById("page_value").value;
var all_page=document.getElementById("all_page").innerHTML;
var page_sure = document.getElementById("page_sure");
if((page_value*1 <= all_page*1 ) && ( page_value*1 > 0) ){
document.page_form.page_sure.disabled="";
page_sure.style.backgroundColor="";
}else{
document.page_form.page_sure.disabled=true;
page_sure.style.backgroundColor="#AAAAAA";
}
}
</script>
';
}
?>

css

/***
* 颜色有:皇军蓝色.blue,深天蓝色.DeepSkyBlue,粉色.pink ,灰色.gray,白色.white
* 类型有:圆形边框.rborder ,灰色边框.cborder,无边框.noborder,阴影边框3灰.shborder3,阴影边框2.shborder2,阴影边框1.shborder1,
* ***************基本**************************************/
.type_fix{
display:block;
line-height:30px;
height: 30px;
width:100%;
text-align:center;
margin:0 auto;
padding-bottom: 55px;
font-size: 14px;
font-family: Cambria, Georgia, serif;
}
.type_fix .page_form{
display: inline;
}
.type_fix a,.type_fix .all_page,.type_fix input{
margin: 5px;
padding: 4px 4px;
border: #CCCCCC 1px solid;
text-decoration:none;
background: none;
}
.type_fix .page_sure{
cursor: pointer;
}
.type_fix .middle_page{
padding: 4px 6px;
}
.type_fix #page_value{
width: 20px; }
.type_fix .page_form{
margin-left: 16px;
}
/******************颜色**************************************/
/*皇军蓝色*/
.blue a,
.blue .all_page,
.blue input{
border: #4F63E3 1px solid;
color: #4F63E3;
}
.blue{
color: #4F63E3;
}
.blue a:hover,
.blue .visit_page{
background: #4F63E3;
color:#FFFFFF;
border: #4F63E3 1px solid;
}
/*深天蓝色*/
.DeepSkyBlue a,
.DeepSkyBlue .all_page,
.DeepSkyBlue input{
border: #35BFFF 1px solid;
color: #35BFFF;
}
.DeepSkyBlue {
color: #35BFFF;
}
.DeepSkyBlue a:hover,
.DeepSkyBlue .visit_page{
background: #35BFFF;
color:#FFFFFF;
border: #35BFFF 1px solid;
}
/*粉色*/
.pink a,
.pink .all_page,
.pink input{
border: #F15481 1px solid;
color: #F15481;
}
.pink {
color: #F15481;
}
.pink a:hover,
.pink .visit_page{
background: #F15481;
color:#FFFFFF;
border: #F15481 1px solid;
}
/*灰色*/
.gray a,
.gray .all_page,
.gray input{
border: #808080 1px solid;
color: #808080;
}
.gray {
color: #808080;
}
.gray a:hover,
.gray .visit_page{
background: #808080;
color:#FFFFFF;
border: #808080 1px solid;
}
/*白色*/
.white a,
.white .all_page,
.white input{
border: #FFFFFF 1px solid;
color: #FFFFFF;
}
.white {
color: #FFFFFF;
}
.white a:hover,
.white .visit_page{
background: #FFFFFF;
color:#000000;
border: #FFFFFF 1px solid;
}
/******************边框**************************************/
/*无边框*/
.noborder a,
.noborder .all_page,
.noborder input{
border:none;
}
.noborder a:hover,
.noborder .visit_page{
background: none;
color: #000000;
border:none;
}
/*灰色边框*/
.cborder a,
.cborder .all_page,
.cborder input,
.cborder a:hover,
.cborder .visit_page{
border: #CCCCCC 1px solid;
} /*圆形边框*/
.rborder a,
.rborder .all_page,
.rborder input,
.rborder a:hover,
.rborder .visit_page{
border-radius: 4px;
} /*阴影边框1斜着*/
.shborder1 a,
.shborder1 .all_page,
.shborder1 input,
.shborder1 a:hover,
.shborder1 .visit_page{ -moz-box-shadow:2px 2px 5px #969696;/*firefox*/
-webkit-box-shadow:2px 2px 5px #969696;/*webkit*/
box-shadow:2px 2px 5px #969696;/*opera或ie9*/
}
/*阴影边框2原色*/
.shborder2 a,
.shborder2 .all_page,
.shborder2 input,
.shborder2 a:hover,
.shborder2 .visit_page{ -webkit-box-shadow:0 0 10px ;
-moz-box-shadow:0 0 10px;
box-shadow:0 0 10px ;
}
/*阴影边框3灰*/
.shborder3 a,
.shborder3 .all_page,
.shborder3 input,
.shborder3 a:hover,
.shborder3 .visit_page{ -webkit-box-shadow:0 1px 3px rgba(34,25,25,0.4);
-moz-box-shadow:0 1px 3px rgba(34,25,25,0.4);
box-shadow:0 1px 3px rgba(34,25,25,0.4);
}
/******************hack**************************************/
/*IE6 & IE7:hack*/
a:focus,*:focus {
noFocusLine: expression(this.onFocus=this.blur());
outline:none;}
*.type_fix *#page_value{
display: inline-block;
margin-bottom: -4px; }
*.type_fix *.page_sure{
line-height: 16px;
height: 26px;
display: inline-block;
margin-bottom: -4px;
filter:chroma(color=#000000);
}
/*火狐hack*/
@-moz-document url-prefix(){
.type_fix .page_sure{
padding: 2px;
}
}

php 调用页

<?php
include("conf/database.php");
$pageSize=35;//每页显示
$page=$_GET['page'];//接收第几页
//接收不到,就是第1页
if($page==""){
$page=1;
}
$showPage=5;//分页条中间 显示几个页的按钮
//得到数据总数
$total_sql="SELECT COUNT(*) FROM `oepre_user_photo`";
$total_result=mysql_fetch_array(mysql_query($total_sql));
$total= $total_result[0];
include("fenye.php");
$page_point=(($page-1)*$pageSize);//分页开始点
?>
 <?php fenye($pageSize,$page,$showPage,$total,'DeepSkyBlue shborder3 noborder') ?>

PHP 相对完整的分页的更多相关文章

  1. 完整SQL分页存储过程(支持多表联接)

    http://www.cnblogs.com/andiki/archive/2009/03/24/1420289.html Code/********************************* ...

  2. 完整的分页存储过程以及c#调用方法

    高效分页存储过程 USE [db] GO /****** 对象: StoredProcedure [dbo].[p_Page2005] 脚本日期: // :: ******/ SET ANSI_NUL ...

  3. CI框架分页类

    分页类1.分页类参数说明 'base_url' => 指向你的分页所在的控制器类/方法的完整的 URL, 'total_rows' => 数据的总行数, 'per_page' => ...

  4. SSM 使用 mybatis 分页插件 pagehepler 实现分页

    使用分页插件的原因,简化了sql代码的写法,实现较好的物理分页,比写一段完整的分页sql代码,也能减少了误差性. Mybatis分页插件 demo 项目地址:https://gitee.com/fre ...

  5. PageHelper分页插件及通用分页js

     分页概述 1.物理分页 物理分页依赖的是某一物理实体,这个物理实体就是数据库,比如MySQL数据库提供了limit关键字,程序员只需要编写带有limit关键字的SQL语句,数据库返回的就是分页结果. ...

  6. 使用layui框架做分页

    第一步引用两个文件: <link href="layui-v2.2.5/layui-v2.2.5/layui/css/layui.css" rel="stylesh ...

  7. SQL2005分页存储过程(支持多表联接)

    Code /*********************************************************   * 作    用:数据分页(完整SQL分页存储过程(支持多表联接)) ...

  8. 【mysql】 mybatis实现 主从表 left join 1:n 一对多 分页查询 主表从表都有查询条件 【mybatis】count 统计+JSON查询

    mybatis实现 主从表 left join  1:n 一对多 分页查询   主表从表都有查询条件+count 需求: ======================================= ...

  9. Mybatis分页插件: pageHelper的使用及其原理解析

    在实际工作中,很进行列表查询的场景,我们往往都需要做两个步骤:1. 查询所需页数对应数据:2. 统计符合条件的数据总数:而这,又会导致我们必然至少要写2个sql进行操作.这无形中增加了我们的工作量,另 ...

随机推荐

  1. visualSFM的使用方法

    VisualSFM是Changchang Wu编写的使用 Structure from Motion (SfM)进行3D重建的交互界面,具体内容详见http://ccwu.me/vsfm/.本人电脑环 ...

  2. 错误号:1364 错误信息:Field 'platId' doesn't have a default value

    1. 错误描述 错误号:1364 错误信息:Field 'platId' doesn't have a default value insert into `use`.`t_platform_scal ...

  3. Caused by:org.hibernate.DuplicateMappingException:Duplicate class/entity/ mapping

    1.错误描述 java.lang.ExceptionInInitializerError Caused by:org.hibernate.InvalidMappingException:Could n ...

  4. 芝麻HTTP:TXT文本存储

    将数据保存到TXT文本的操作非常简单,而且TXT文本几乎兼容任何平台,但是这有个缺点,那就是不利于检索.所以如果对检索和数据结构要求不高,追求方便第一的话,可以采用TXT文本存储.本节中,我们就来看下 ...

  5. xml的Dom4j解析规则

    一,xml的样本 <?xml version="1.0" encoding="utf-8"?> <contactList> <co ...

  6. 异常-----Can't convert the date to string, because it is not known which parts of the date variable are in use. Use ?date, ?time or ?datetime built-in, or ?string.\u003Cformat> or ?string(format) built-

    1.错误描述 五月 27, 2014 12:07:05 上午 freemarker.log.JDK14LoggerFactory$JDK14Logger error 严重: Template proc ...

  7. 基于python机器学习人脸自动补全

    import numpy as np import matplotlib.pyplot as plt from sklearn.linear_model import LinearRegression ...

  8. 【CJOJ P2226】[省常中2011S4] 圣诞节

    Description 圣诞节到了,FireDancer准备做一棵大圣诞树.下图为圣诞树的一个简单结构. 这棵树被表示成一组被编号的结点和一些边的集合.结点从1到n编号.树的根永远是1.每个结点都有一 ...

  9. 剑指offer-(19)顺时针打印矩阵

    题目描述 输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下矩阵: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 则依次打印出数字1,2, ...

  10. redis学习系列——redis持久化

    1.写操作的流程 2.RDB快照-redis的第一个持久化策略 第一种是以快照的形式持久化到本地磁盘(RDB文件). 持久化策略是: 1.配置(save N M)在N秒内,redis至少发生M次修改, ...