php的网页效果,PHP如何实现网页分页效果

在PHP网站之说,有很多需要实现分页效果,主要是用于阅读小说。

功能实现如下:

使用sql查询进行分页时,需要调用几个函数,具体见脚本:

1.pager.class.php

1、首先了解SQL语句中的limit用法

SELECT * FROM table …… limit 开始位置 , 操作条数 (其中开始位置是从0开始的)

例子:

取前20条记录:SELECT * FROM table …… limit 0 , 20

从第11条开始取20条记录:SELECT * FROM table …… limit 10 , 20

LIMIT n 等价于 LIMIT 0,n。

如select * from table LIMIT 5; //返回前5行,和 select * from table LIMIT 0,5一样

2、分页原理

所谓分页显示,也就是讲数据库中的结果集,一段一段显示出来

怎么分段,当前在第几段 (每页有几条,当前再第几页)

前10条记录:select * from table limit 0,10

第11至20条记录:select * from table limit 10,10

第21至30条记录:select * from table limit 20,10

分页公式:

(当前页数 - 1 )X 每页条数 , 每页条数

Select * from table limit ($Page- 1) * $PageSize, $PageSize

3、$_SERVER["REQUEST_URI"]函数

预定义服务器变量的一种,所有$_SERVER开头的都叫做预定于服务器变量。

REQUEST_URI的作用是取得当前URI,也就除域名外后面的完整的地址路径。

例子:

当前页为:http://www.test.com/home.php?id=23&cid=22

echo $_SERVER["REQUEST_URI"]

结果为:/home.php?id=23&cid=22

4、parse_url()解析URL函数

parse_url() 是讲URL解析成有固定键值的数组的函数

例子

$ua=parse_url("http://username:password@hostname/path?arg=value#anchor");

print_r($ua);

结果:

Array

(

[scheme] => http ;协议

[host] => hostname ;主机域名

[user] => username ;用户

[pass] => password ;密码

[path] => /path ;路径

[query] => arg=value ;取参数

[fragment] => anchor ;

)

5、代码实例

这个一个留言的分页,分为3个部分,一个是数据库设计,一个是连接页面,一个是显示页面。

(1)设计数据库

设计数据库名为bbs,有一个数据表为message,里面包含title,lastdate,user,content等字段,分别表示留言标题,留言日前,留言人,留言的内容

(2)连接页面

$conn = @ mysql_connect("localhost", "root", "123456") or die("数据库链接错误");

mysql_select_db("bbs", $conn);

mysql_query("set names 'GBK'"); //使用GBK中文编码;

//将空格,换行转换为HTML可解析

function htmtocode($content) {

$content = str_replace("\n", "

", str_replace(" ", " ", $content)); //两个str_replace嵌套

return $content;

}

//$content=str_replace("'","‘",$content);

//htmlspecialchars();

?>

(3)显示页面

$pagesize=2; //设置每页显示2个记录

$url=$_SERVER["REQUEST_URI"];

$url=parse_url($url);

$url=$url[path];

$numq=mysql_query("SELECT * FROM `message`");

$num = mysql_num_rows($numq);

if($_GET[page]){

$pageval=$_GET[page];

$page=($pageval-1)*$pagesize;

$page.=',';

}

if($num > $pagesize){

if($pageval<=1)$pageval=1;

echo "共 $num 条".

" 上一页 下一页";

}

$SQL="SELECT * FROM `message` limit $page $pagesize ";

$query=mysql_query($SQL);

while($row=mysql_fetch_array($query)){

?>

标题: 时间:

用户:

内容:

\n";

echo "\n";

echo "

\n";

echo "\n";

//rating_bar($title[$a],5);

echo "\n";

echo "$hotelname[$a]\n";

echo "\n";

echo "

\n";

echo "\n";

echo "\n";

echo "

comment.gif%5C%22 推荐人数:($countpeople[$a]) |\n";

echo "平均分: (".$count."票) | 评论数:()\n";

echo "\n";

}

echo " echo "border=0>";

echo "";

echo "";

echo "

第".$page."页/总".$pages."页 | 总".$numrows."条 | ";

if ($page>1) echo "首页 | ";

if ($page>1) echo "上页 | ";

if ($page if ($page echo "转到第 页 ";

echo "";

本条技术文章来源于互联网,如果无意侵犯您的权益请点击此处反馈版权投诉

本文系统来源:php中文网

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值