php分页代码
楼上的光有上页和下页,我来做个【首页】【上页】【下页】【末页】的。
<?php
$result_num1 = mysql_query("SELECT * FROM article");
$num1 = mysql_num_rows($result_num1);
$pagesize1 = 10;
$start1 = $_GET['start1'];
$flag1 = $_GET['flag1'];
//判断$start1是否有值
if ($start1 == null) {
$start1 = 0;
}
//判断完毕
//判断$flag1是否有值
if ($flag1 == null) {
$flag1 = 0;
}
//判断完毕
//判断标志位以确定$start1的值
if ($flag1 == 1 and $start1+$pagesize1 < $num1){
$start1 = $start1+$pagesize1;
}
if ($flag1 == 2 and $start1+$pagesize1 > 0){
$start1 = $start1-$pagesize1;
}
//判断完毕
$query_proct_type = "SELECT art_title FROM article limit $start1, $pagesize1";
$result_proct_type = mysql_query($query_proct_type) or die("Query failed : " . mysql_error());
print ("<table width='100%'>
<tr>
<td valign='top' height = '188'>
<table width='100%'>");
while ($line_proct = mysql_fetch_array($result_proct_type, MYSQL_ASSOC)) {
print ("<tr>");
foreach ($line_proct as $col_value_proct_type) {
$result_proct = mysql_query ("SELECT * FROM article WHERE art_title ='$col_value_proct_type'");
$click_proct = mysql_fetch_array($result_proct) ;
print ("<td width='5%'><img border='0' src='../images/kind_list1.GIF' width='9' height='11'></td>");
print ("<td width='95%'><a href='view_article.php?art_title=$click_proct[0]' target='view_article'><span style='font-size:
9pt'>$click_proct[0]</span></a></td>");
}
print ("</tr>");
}
print ("</table>
</td></tr>");
//最后一页START标识
if (($num1 % $pagesize1) != 0){
$lastpage1 = $num1 - ($num1 % $pagesize1);
}else{
$lastpage1 = $num1 - $pagesize1;
}
//代码结束
//判断页数以及当前页代码
$pagenum1 = ceil($num1 / $pagesize1);
if ($start1 == 0){
$nowpage1 = 1;
}else{
$nowpage1 = ($start1 / $pagesize1) + 1;
}
//判断结束
print ("<tr>
<td><hr color='#314DA5' size='1' noshade style='border-style: dotted; border-width: 1px; padding: 0'></td>
</tr>
<tr>
<td><p align='center'><span style='font-size: 9pt'>第<font color = '#FF0000'><b>$nowpage1</b></font>页 | 共<font color =
'#FF0000'><b>$pagenum1</b></font>页 | 共<font color = '#FF0000'><b>$num1</b></font>条记录</span></td>
</tr>
<tr>
<td><p align='center'>");
//分页显示判断部分
if ($start1 == 0 and $pagesize1 < $num1){
print ("<span style='font-size: 9pt'>【首页】【上页】<a href ='page_.php?flag1=1&start1=$start1'>【下页】</a><a href ='page_.php?start1=$lastpage1'>【末页】</a></span>");
}elseif ($start1 >= $num1-$pagesize1 and $pagesize1 < $num1){
print ("<span style='font-size: 9pt'><a href ='page_.php?start1=0'>【首页】</a><a href ='page_.php?flag1=2&start1=$start1'>【上页】</a>【下页】【末页】</span>");
}elseif ($pagesize1 >= $num1 ){
print ("<span style='font-size: 9pt'>【首页】【上页】【下页】【末页】</span>");
}else{
print ("<span style='font-size: 9pt'><a href ='page_.php?start1=0'>【首页】</a><a href ='page_.php?flag1=2&start1=$start1'>【上页】</a><a href ='page_.php?flag1=1&start1=$start1'>【下页】</a><a href ='page_.php?start1=$lastpage1'>【末页】</a></span>");
}
//分页代码判断结束
print ("</td>
</tr></TABLE>");
mysql_free_result($result_proct_type);
?>
考虑到安全问题,数据库信息部分已经省略。
运行结果请查看:
http://www.eternity2008.com/test/page_.php
有问题请留言,或登陆http://www.eternity2008.com论坛联系。
⑵ php分页显示
<?
$sql="select * from table ";//查表
$res=mysql_query($sql);//取得结果
$nums=mysql_num_rows($res);//取得总记录数
$pagesize=15;//设定每页的记录数
$pages=ceil($nums/$pagesize);//取得总页数
if($pages<1){$pages=1;}//设定总页数至少1页
$page=$_GET[page];//取得传递过来的页数
if($page>$pages){$page=$pages;}//如果传递过来的页数比总页数还大,就让它等于总页数
if($page<1){$page=1;}//如果传递过来的页数小于1,就让他等于1
$kaishi=($page-1)*$pagesize;//为下一步做准备,limit的初始记录
$sql="select * from table order by id desc limit $kaishi,$pagesize";//取得记录从计算出的初始值开始,一共$pagesize条
$res=mysql_query($sql);//取得结果
while($arr=mysql_fetch_array($res))
{
echo $arr[id]."---".$arr[biaoti].'<br>';//输出记录的ID和标题
}
?>
下面是分页<br />
<a href="?page=1">首页</a> <a href="?page=<? echo $page-1;?>">上页</a> 当前第<? echo $page;?>页 <a href="?page=<? echo $page+1;?>">下页</a> <a href="?page=<? echo $pages;?>">尾页</a>
⑶ 如何整理PHP分页代码,使其实现经典分页样式
如何整理PHP分页代码,使其实现经典分页样式
<?php
require_once("conn.php");
$ind_cont_sel_sql="select * from `board` order by `sn` desc";
$ind_cont_sel_query = mysql_query($ind_cont_sel_sql);
$page_info_num = 3;
$page_def = 1;
if (isset($_GET['pagenum'])){
$page_def = $_GET['pagenum'];
}
$sql_page_num = ($page_def - 1)*$page_info_num;
$sql_query_limit=$ind_cont_sel_sql." LIMIT ".$sql_page_num.",".$page_info_num;
$sql_query_limit_info=mysql_query($sql_query_limit);
$all_info_num = mysql_num_rows($ind_cont_sel_query);
$all_page_num = ceil($all_info_num/$page_info_num);
?>
<table width="100%" border="0">
<?php
$i=0;
while($ind_cont_sel_row=mysql_fetch_assoc($sql_query_limit_info)){ $i++; ?>
<tr>
<td colspan="2"><div class="post-utility"><p><h1><u><?php echo $sql_page_num+$i;?></u></h1></p></div></td>
</tr>
<tr>
<td width="80px"><p>title</p></td><td><?php echo nl2br($ind_cont_sel_row["title"]);?></td>
</tr>
<tr>
<td width="80px"><p>name</p></td><td><?php echo nl2br($ind_cont_sel_row["name"]);?></td>
</tr>
<tr>
<td width="80px"><p>time</p></td><td><?php echo nl2br($ind_cont_sel_row["time"]);?></td>
</tr>
<tr>
<td width="80px"><p>content</p></td><td><?php echo nl2br($ind_cont_sel_row["content"]);?></td>
</tr>
<tr><td colspan="2"><hr></td></tr>
<?php } ?>
<tr><td colspan="2" height="10px" align="center">
<a href="?pagenum=1">page</a>
<?
if ($_GET["pagenum"]!=1){ ?>
<a href="?pagenum=<? echo $_GET["pagenum"]-1; ?>">up</a>
<?
}else{
echo "";
} ?>
<?
for($page_num=($_GET["pagenum"]-2);$page_num<$_GET["pagenum"];$page_num++){
if ($page_num<=0){
echo "";
}else{?>
<a href="?pagenum=<?php echo $page_num;?>"><?php echo $page_num;?></a>
<?
}}
?>
<?php echo $_GET["pagenum"];?>
<!--<a href="?pagenum=<?php echo $_GET["pagenum"];?>"><?php echo $_GET["pagenum"];?></a>-->
<?
for($page_num=$_GET["pagenum"]+1;$page_num<=($_GET["pagenum"]+2);$page_num++){
if ($page_num>$all_page_num){
echo "";
}else{
?>
<a href="?pagenum=<?php echo $page_num;?>"><?php echo $page_num;?></a>
<?
}
}
?>
<?
if ($_GET["pagenum"]<$all_page_num){ ?>
<a href="?pagenum=<? echo $_GET["pagenum"]+1; ?>">next</a>
<?
}else{
echo "";
} ?>
<a href="?pagenum=<?php echo $all_page_num;?>">last</a>
</td>
</tr>
</table>
⑷ php怎么实现分页
/**
* 获取分页的HTML内容
* @param integer $page 当前页
* @param integer $pages 总页数
* @param string $url 跳转url地址 最后的页数以 '&page=x' 追加在url后面
*
* @return string HTML内容;
*/
public static function getPageHtml($page, $pages, $url){
//最多显示多少个页码
$_pageNum = 5;
//当前页面小于1 则为1
$page = $page<1?1:$page;
//当前页大于总页数 则为总页数
$page = $page > $pages ? $pages : $page;
//页数小当前页 则为当前页
$pages = $pages < $page ? $page : $pages;
//计算开始页
$_start = $page - floor($_pageNum/2);
$_start = $_start<1 ? 1 : $_start;
//计算结束页
$_end = $page + floor($_pageNum/2);
$_end = $_end>$pages? $pages : $_end;
//当前显示的页码个数不够最大页码数,在进行左右调整
$_curPageNum = $_end-$_start+1;
//左调整
if($_curPageNum<$_pageNum && $_start>1){
$_start = $_start - ($_pageNum-$_curPageNum);
$_start = $_start<1 ? 1 : $_start;
$_curPageNum = $_end-$_start+1;
}
//右边调整
if($_curPageNum<$_pageNum && $_end<$pages){
$_end = $_end + ($_pageNum-$_curPageNum);
$_end = $_end>$pages? $pages : $_end;
}
$_pageHtml = '<ul class="pagination">';
/*if($_start == 1){
$_pageHtml .= '<li><a title="第一页">«</a></li>';
}else{
$_pageHtml .= '<li><a title="第一页" href="'.$url.'&page=1">«</a></li>';
}*/
if($page>1){
$_pageHtml .= '<li><a title="上一页" href="'.$url.'&page='.($page-1).'">«</a></li>';
}
for ($i = $_start; $i <= $_end; $i++) {
if($i == $page){
$_pageHtml .= '<li class="active"><a>'.$i.'</a></li>';
}else{
$_pageHtml .= '<li><a href="'.$url.'&page='.$i.'">'.$i.'</a></li>';
}
}
/*if($_end == $pages){
$_pageHtml .= '<li><a title="最后一页">»</a></li>';
}else{
$_pageHtml .= '<li><a title="最后一页" href="'.$url.'&page='.$pages.'">»</a></li>';
}*/
if($page<$_end){
$_pageHtml .= '<li><a title="下一页" href="'.$url.'&page='.($page+1).'">»</a></li>';
}
$_pageHtml .= '</ul>';
echo $_pageHtml;
}
⑸ php文章列表分页代码怎么写
Web开发是今后分布式程式开发的主流,通常的web开发都要涉及到与数据库打交道,客户端从服务器端读取通常都是以分页的形式来显示,一页一页的阅读起来既方便又美观。所以说写分页程序是web开发的一个重要组成部分,在这里,我们共同来研究分页程序的编写。
⑹ php分页代码:www.gotoway.com新闻分页那个功能怎么实现
那个分页我看没什么特别的?
⑺ 求简单的php分页代码一定要是简单最好可以详细解释的,如果可以希望高手能把这段代码加上分页
<body>
<?
/*
'PID 页面中的其它传参连接
'page 要显示的页码
'Vcount 总记录数
'Pnum 每页记录数
'className 超连接样式
*/
function ThePage($Pid,$page=1,$Vcount,$Pnum,$className){
$Pcount = ceil($Vcount/$Pnum);
if($page>$Pcount) $page=$Pcount;
$StartPageNum=1;
while($StartPageNum+10<=$page){
$StartPageNum=$StartPageNum+10;
}
$EndPageNum=$StartPageNum+9 ;
if($EndPageNum>$Pcount) $EndPageNum=$Pcount;
$show = $show."<tr><td colspan='10' bgcolor='' align='right' style='padding-right:25px;padding-top:5px;' class='".$className."'>";
$show = $show."共<b>".$Pcount."</b>页 共有<b>".$Vcount."</b>记录 第<b>".$page."</b>页 跳到第 [ ";
if($StartPageNum>1) $show = $show."<a class='".$className."' href='?".$Pid."page=".($StartPageNum-1)."' title='前十页'><font face='webdings'>7</font></a>";
for($go=$StartPageNum;$go<=$EndPageNum;$go++){
if($go!=$page){
$show = $show."<a class='".$className."' href='?".$Pid."page=".$go."'>".$go."</a>";
}else{
$show = $show."<b>".$go."</b>";
}
$show = $show." ";
}
if($EndPageNum<$Pcount) $show = $show."<a class='".$className."' href='?".$Pid."page=".($EndPageNum+1)."' title='下十页'><font face='webdings'>8</font></a>";
$show = $show."] 页";
if($page!=1) $show = $show."<a class='".$className."' href='?".$Pid."page=1'> 首页</a> <a class='".$className."' href='?".$Pid."page=".($page-1)."'>上一页</a>";
if($Pcount-$page!=0) $show = $show. "<a class='".$className."' href='?".$Pid."page=".($page+1)."'> 下一页</a> <a class='".$className."' href='?".$Pid."page=".$Pcount."'>尾页</a>";
$show=$show."</tr></td>";
return $show;
}
?>
<?php
//连上数据库
mysql_connect("localhost","root","");
//选择数据库
mysql_select_db("company");
//执行数据库命令
mysql_query("set names 'utf8'");
//关闭数据库就是使用的最近的数据库
echo "<a><font color=red>已查到的记录:</font></a>"."<font color=red>
共".mysql_num_rows
($rs)."条</font>"."<br>"."<br>";
?>
<input type="button" value="添加员工" onclick="location.href='empadd.html'" />
<form class="bd">
<table border="1" align="left" bordercolor="blue" background="27[1].jpg" >
<td align="center"><font color=#0000FF>职员编号</font></td>
<td align="center"><font color=#0000FF>职员姓名</font></td>
<td align="center"><font color=#0000FF>职员职位</font></td>
<td align="center"><font color=#0000FF>职员经理</font></td>
<td align="center"><font color=#0000FF>入职日期</font></td>
<td align="center"><font color=#0000FF>职员工资</font></td>
<td align="center"><font color=#0000FF>所在部门</font></td>
<td align="center" width="100" height="20"><font color=#0000FF>操作</font></td>
</tr>
<?
//设置参数
$page = $_REQUEST["page"];
if($page=="") $page = 1;
$Pid = "";
$Pnum = 10;
$classname = "lwf";
//以下不用修改
$rs = mysql_query("select count(*) from emp e1 left join emp e2 on e1.mgr = e2.empno left join dept on e1.deptno = dept.deptno");
$Vcount = @mysql_result($rs,0);
@mysql_free_result($rs);
$start = ($page - 1) * $Pnum;
$lastNum = $Vcount - ($page - 1) * $Pnum;
$limit = $lastNum > $Pnum ? $Pnum : $lastNum;
$rs = mysql_query("select e1.empno, e1.ename, e1.job, e1.mgr, e1.hiredate, e1.sal, e1.deptno, e2.ename as mname, dname from emp e1 left join emp e2 on e1.mgr = e2.empno left join dept on e1.deptno = dept.deptno LIMIT $start,$limit");
while($ary = mysql_fetch_array($rs)){
?>
<tr bordercolor="blue">
<td width="80" height="20" align="center"><?php echo $a["empno"];?> </td>
<td width="80" height="20" align="center"><?php echo $a["ename"];?> </td>
<td width="80" height="20" align="center"><?php echo $a["job"];?> </td>
<td width="80" height="20" align="center"><?php echo $a["mname"];?> </td>
<td width="150" height="20" align="center"><?php echo $a["hiredate"];?> </td>
<td width="80" height="20" align="center"><?php echo $a["sal"];?> </td>
<td width="80" height="20" align="center"><?php echo $a["dname"];?> </td>
<td width="90" height="20" align="center">
<a href="empedit.php?aa=<?php echo $a['empno']?>">修改</a> |
<a href="empdel.php?aa=<?php echo $a['empno']?>">删除</a></td>
</tr>
<?
}
@mysql_free_result($rs);
echo ThePage($Pid,$page,$Vcount,$Pnum,$classname);
?>
</table>
</form>
</body>
⑻ PHP一个页面两个分页,如何实现,求具体代码!!!!
我可以给你讲讲思路,你按照我写的修改就行了:
分页的思路:
a.求得数据总的记录条数
$sql="select * from 表名";
b.确定每页显示的记录条数
$pagesize=3;
c.求的总的页数
$countPage=ceil($number/$pagesize);
d.取得当前的页码
$nowpage = isset($_GET['pa'])?$_GET['pa']:1;
e.求的开始位置,利用limit拼写sql语句
$start=(当前页码-1)*每页显示的记录条数
⑼ php分页代码
<?php
/**
* @author SEPH
* @desc pageft
* @date 2009-4-20
*/
//为了避免重复包含文件而造成错误,加了判断函数是否存在的条件:
if(!@function_exists(pageft)){
//定义函数pageft(),三个参数的含义为:
//$totle:信息总数;
//$displaypg:每页显示信息数,这里设置为默认是20;
//$url:分页导航中的链接,除了加入不同的查询信息“page”外的部分都与这个URL相同。
// 默认值本该设为本页URL(即$_SERVER["REQUEST_URI"]),但设置默认值的右边只能为常量,所以该默认值设为空字符串,在函数内部再设置为本页URL。
function pageft($totle,$displaypg=20,$url=''){
//定义几个全局变量:
//$page:当前页码;
//$firstcount:(数据库)查询的起始项;
//$pagenav:页面导航条代码,函数内部并没有将它输出;
//$_SERVER:读取本页URL“$_SERVER["REQUEST_URI"]”所必须。
global $page,$firstcount,$pagenav,$_SERVER;
//为使函数外部可以访问这里的“$displaypg”,将它也设为全局变量。注意一个变量重新定义为全局变量后,原值被覆盖,所以这里给它重新赋值。
$GLOBALS["displaypg"]=$displaypg;
/*if(!$page) $page=1*/;
if(@$_GET['page'])
$page = intval($_GET['page']);
else
$page = 1;
//如果$url使用默认,即空值,则赋值为本页URL:
if(!$url){ $url=$_SERVER["REQUEST_URI"];}
//URL分析:
$parse_url=parse_url($url);
$url_query=@$parse_url["query"]; //单独取出URL的查询字串
if($url_query){
//因为URL中可能包含了页码信息,我们要把它去掉,以便加入新的页码信息。
//这里用到了正则表达式,请参考“PHP中的正规表达式”(http://www.pconline.com.cn/pce/empolder/wz/php/10111/15058.html)
$url_query=ereg_replace("(^|&)page=$page","",$url_query);
//将处理后的URL的查询字串替换原来的URL的查询字串:
$url=str_replace($parse_url["query"],$url_query,$url);
//在URL后加page查询信息,但待赋值:
if($url_query) $url.="&page"; else $url.="page";
}else {
$url.="?page";
}
//页码计算:
$lastpg=ceil($totle/$displaypg); //最后页,也是总页数
$page=min($lastpg,$page);
$prepg=$page-1; //上一页
$nextpg=($page==$lastpg ? 0 : $page+1); //下一页
$firstcount=($page-1)*$displaypg;
//开始分页导航条代码:
$pagenav="显示第 <B>".($totle?($firstcount+1):0)."</B>-<B>".min($firstcount+$displaypg,$totle)."</B> 条记录,共 $totle 条记录<BR>";
//如果只有一页则跳出函数:
if($lastpg<=1) return false;
$pagenav.=" <a href='$url=1' target=_self>首页</a> ";
if($prepg) $pagenav.=" <a href='$url=$prepg' target=_self>前页</a> "; else $pagenav.=" 前页 ";
if($nextpg) $pagenav.=" <a href='$url=$nextpg' target=_self>后页</a> "; else $pagenav.=" 后页 ";
$pagenav.=" <a href='$url=$lastpg' target=_self>尾页</a> ";
//下拉跳转列表,循环列出所有页码:
$pagenav.=" 到第 <select name='topage' size='1' onchange='window.location=\"$url=\"+this.value'>\n";
for($i=1;$i<=$lastpg;$i++){
if($i==$page) $pagenav.="<option value='$i' selected>$i</option>\n";
else $pagenav.="<option value='$i'>$i</option>\n";
}
$pagenav.="</select> 页,共 $lastpg 页";
}
}/*没有用Get传值*/
?>
⑽ php分页,最好能直接给源码,谢谢
--,--!网络一搜一大把!
你懒得搜我帮你。。。
<!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<htmlxmlns="http://www.w3.org/1999/xhtml">
<head>
<metahttp-equiv="Content-Type"content="text/html;charset=gb2312"/>
<title>phpmakepagelist</title>
<styletype="text/CSS">
<!--
.pagea:link{
color:#0000FF;
text-decoration:none;
}
.pagea:visited{
text-decoration:none;
color:#0000FF;
}
.pagea:hover{
text-decoration:none;
color:#0000FF;
}
.pagea:active{
text-decoration:none;
color:#0000FF;
}
.page{color:#0000FF;}
-->
</style>
</head>
<body>
<tablewidth="530"height="103"border="0"align="center"cellpadding="0"cellspacing="1"bgcolor="#CCCCCC">
<tr>
<thwidth="30"height="38"bgcolor="#E3E3E3"scope="col">ID</th>
<thwidth="500"bgcolor="#E3E3E3"scope="col">文章标题</th>
</tr>
<?php
/*
*Createdon2010-4-17
*
*OrderbyKoveWong
*/
$link=MySQL_connect('localhost','root','haoxiazai1987');
mysql_select_db('pagelist');
mysql_query('setnamesgbk');
$Page_size=10;
$result=mysql_query('select*fromv_char');
$count=mysql_num_rows($result);
$page_count=ceil($count/$Page_size);
$init=1;
$page_len=7;
$max_p=$page_count;
$pages=$page_count;
//判断当前页码
if(empty($_GET['page'])||$_GET['page']<0){
$page=1;
}else{
$page=$_GET['page'];
}
$offset=$Page_size*($page-1);
$sql="select*fromv_charlimit$offset,$Page_size";
$result=mysql_query($sql,$link);
while($row=mysql_fetch_array($result)){
?>
<tr>
<tdbgcolor="#E0EEE0"height="25px"><divalign="center">
<?phpecho$row['id']?>
</div></td>
<tdbgcolor="#E0EEE"><divalign="center">
<?phpecho$row['name']?>
</div></td>
</tr>
<?php
}
$page_len=($page_len%2)?$page_len:$pagelen+1;//页码个数
$pageoffset=($page_len-1)/2;//页码个数左右偏移量
$key='<divclass="page">';
$key.="<span>$page/$pages</span>";//第几页,共几页
if($page!=1){
$key.="<ahref="".$_SERVER['PHP_SELF']."?page=1">第一页</a>";//第一页
$key.="<ahref="".$_SERVER['PHP_SELF']."?page=".($page-1)."">上一页</a>";//上一页
}else{
$key.="第一页";//第一页
$key.="上一页";//上一页
}
if($pages>$page_len){
//如果当前页小于等于左偏移
if($page<=$pageoffset){
$init=1;
$max_p=$page_len;
}else{//如果当前页大于左偏移
//如果当前页码右偏移超出最大分页数
if($page+$pageoffset>=$pages+1){
$init=$pages-$page_len+1;
}else{
//左右偏移都存在时的计算
$init=$page-$pageoffset;
$max_p=$page+$pageoffset;
}
}
}
for($i=$init;$i<=$max_p;$i++){
if($i==$page){
$key.='<span>'.$i.'</span>';
}else{
$key.="<ahref="".$_SERVER['PHP_SELF']."?page=".$i."">".$i."</a>";
}
}
if($page!=$pages){
$key.="<ahref="".$_SERVER['PHP_SELF']."?page=".($page+1)."">下一页</a>";//下一页
$key.="<ahref="".$_SERVER['PHP_SELF']."?page={$pages}">最后一页</a>";//最后一页
}else{
$key.="下一页";//下一页
$key.="最后一页";//最后一页
}
$key.='</div>';
?>
<tr>
<tdcolspan="2"bgcolor="#E0EEE0"><divalign="center"><?phpecho$key?></div></td>
</tr>
</table>
</body>
</html>