php代码简述分页原理,PHP分页原理

PHP分页原理

分页是网站上常用的一种信息显示手段,比如网上的评论,有时候会有几百条上千条甚至几十万条,同时在一个页面上显示显然不和实际,所以,我们就要用到分页了。

实现分页需要访问mysql数据库中所存入的数据,所以我们得新建一个数据库,并在数据库中建一个表:

A020244572-56239.jpg_small.jpg

(以上数据是我抽风随便打的,不喜请扔砖)

然后呢,我们再使用EPP3建一个工程,我习惯在工程下新建两个php文件,一个用来连接数据库,一个用来实现简单分页:

用来连接数据库的代码:

文件一:conn.php

$conn = @mysql_connect("localhost","root","") ordie("错误连接");

mysql_select_db("nettext",$conn);

mysql_query("set names 'GBK'");

(关键代码)

functionhtmlCode($contect){

$contect = str_replace("\n","
", str_replace(" "," ", $contect));

$contect = str_replace("你好","***", $contect);//屏蔽关键字

return$contect;

}

?>

用来实现分页的代码:

include("conn.php");

$pagesize = 5;

$url = $_SERVER["REQUEST_URI"];

//获取路径

$url = parse_url($url);

//解析一个 URL并返回一个

$url = $url[path];

//获得关联数组中的path部分

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

//获取表:softwaresix中的所有数据

$num = mysql_num_rows($numq);

//获取条数

if($_GET[page]){

$pageval=$_GET[page];

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

$page.=',';

}

//page是显示分段信息的起始信息条的序号,pageval是页码,pagesize是每页显示的条数;

if($num > $pagesize){//如果数据总数大于每页显示条数在显示下一页和上一页

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

echo"共$num条".

" 上一页 下一页";

}

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

$query = mysql_query($SQL);

while($row = mysql_fetch_array($query)){//逐条在页面上显示信息

echo"


".$row[id]." | ".$row[uid];

}

?>

下面我们来理清一下做分页的思路:

前提:

需要建立一个数据库,这个数据库有一个有一定数量信息的表;

基本:

1、建立php与数据库之间的联系;

2、获取路径——解析一个 URL并返回一个——获得关联数组中的path部分;

3、获取表中数据和信息条数;

4、分页公式:

if($_GET[page]){

$pageval=$_GET[page];

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

$page.=',';

}

//page是显示分段信息的起始信息条的序号,pageval是页码,pagesize是每页显示的条数;

5、上下页按钮:

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

echo"共$num条".

" 上一页 下一页";

6、将信息显示在页面上:

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

$query = mysql_query($SQL);

while($row = mysql_fetch_array($query)){//逐条在页面上显示信息

echo"


".$row[id]." | ".$row[uid];

}

增强用户体验的优化:

if($num > $pagesize){//如果数据总数大于每页显示条数在显示下一页和上一页

……………………

}

其实,这只是最简单的分页操作,网站中的分页要比这个复杂很多,网络上也有别人写好的类可以使用。

接下来要完善这个分类,就需要我们共同的努力啦~

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值