百分百源码网-让建站变得如此简单! 登录 注册 签到领金币!

主页 | 如何升级VIP | TAG标签

当前位置: 主页>网站教程>网页制作> php实现分页的道理及步骤
分享文章到:

php实现分页的道理及步骤

发布时间:09/01 来源:未知 浏览: 关键词:

一、封装配置信息

1、我们可以做一个配置文件config.php。将需要使用到的配置全部设定为常量,代码如下:

<?php
//数据库效劳器
define('DB_HOST', 'localhost');
//数据库会员名
define('DB_USER', 'root');
//数据库密码
define('DB_PWD', 'secret');
//库名
define('DB_NAME', 'book');
//字符集
define('DB_CHARSET', 'utf8');

2、2.我们将connection.php页面抽取出来,今后需要连接数据库的时候只需要包括connection.php文件即可。

代码如下:

<?php
include 'config.php';$conn = mysqli_connect(DB_HOST, DB_USER, DB_PWD, DB_NAME);
if (mysqli_errno($conn))
 {  mysqli_error($conn);
    exit;
  }
mysqli_set_charset($conn, DB_CHARSET);
?>

我们在今后每个文件使用中直接包括 connection.php文件就可以实现数据库连接了:

include 'connection.php';

二、显示分页实现

页要实现分页中包括以下几个根本元素:

分页.jpg

我们在操纵页码的时候,都是通过URL地址栏传入页码值来实现的页码操纵。在page.php后面接上页码的相关信息,我们就能够算出更多的有效信息。url操纵分页的结果如下:

分页.png

在代码实现中,是通过limit后的偏移量(offset)和数目(num),这两个值真正实现的分页。

limit offset , num

分页01.jpg

假设每页显示5条。终究得到的分页中操纵limit公式如下:

offset的值为 (n-1)*5
num 为规定的5

三、实现步骤;

1、运算出分页所需参数

1-1、总数

通过查询user表的count(id),得到总数$count。
$count_sql = 'select count(id) as c from user';
$result = mysqli_query($conn, $count_sql);
$data = mysqli_fetch_assoc($result);
//得到总的会员数
$count = $data['c'];

1-2、当前页

刚进入page.php页时,url为http://www.php.com/page.php,后面是不存在 ?page=1 页面标识号的。

因此我们需要手动创立一个页面标识号传给当前页码变量$page。

我们惧怕会员传的页面中存在小数等,所以我们做一次强迫的类型转换:(int) $_GET['page']。

第一种写法:

$page = isset($_GET['page']) ? (int) $_GET['page'] : 1;

第二种写法:

if (isset($_GET['page'])) {
    $page = (int) $_GET['page'];
} else {
    $page = 1;
}

1-3、最后一页

每一页必然是一个整数。就跟小学的时候数学一样。均匀有5.6个人应当预备几个iphone。答案必然是6个。

假如页面出来了20.3个页面,必然是使用进一法取整函数ceil。让分页数变为21。

我们用总数除以每页显示的数据条数,就得到了总页数了。

//每页显示数
$num = 5;
$total = ceil($count / $num);

1-4、上下页非常状况操纵

假如会员的在第一页点击了上一页,在最后一页点击了下一页如何办呢?

这样的话数据会超出范畴,而造成我们分页时很多据显示。

明显这种非常状况需要思考到。因此,假如在分页时在第一页减一时,我们就让他为第一页。
在最后一页加一时,我们就让他为最后一页,即完成了非常操纵。

if ($page <= 1) {
    $page = 1;
}
if ($page >= $total) {
    $page = $total;
}

2、SQL语句

我们此前说过分页的中心是通过SQL语句中的offset和num来操纵每页显示数。

$num = 5;
$offset = ($page - 1) * $num;

我们将$num和$offset利用于SQL语句中:

$sql = "select id,username,createtime,createip from user order by id desc limit $offset , $num";

操纵好URI中的分页值

echo '<tr>
    <td colspan="5">
    <a href="page.php?page=1">首页</a>
    <a href="page.php?page=' . ($page - 1) . '">上一页</a>
    <a href="page.php?page=' . ($page + 1) . '">下一页</a>
    <a href="page.php?page=' . $total . '">尾页</a>
    当前是第 ' . $page . '页  共' . $total . '页
    </td>
    </tr>';

四、团体代码实现

include 'connection.php';
$count_sql = 'select count(id) as c from user';
$result = mysqli_query($conn, $count_sql);
$data = mysqli_fetch_assoc($result);
//得到总的会员数
$count = $data['c'];
$page = isset($_GET['page']) ? (int) $_GET['page'] : 1;
/*
if (isset($_GET['page'])) {
    $page = (int) $_GET['page'];
} else {
    $page = 1;
}
 */
 
//每页显示数
$num = 5;
//得到总页数
$total = ceil($count / $num);
if ($page <= 1) {
    $page = 1;
}
if ($page >= $total) {
    $page = $total;
}
$offset = ($page - 1) * $num;
$sql = "select id,username,createtime,createip from user order by id desc limit $offset , $num";
$result = mysqli_query($conn, $sql);
if ($result && mysqli_num_rows($result)) {
    //存在数据则轮回将数据显示出来
    echo '<table width="800" border="1">';
    while ($row = mysqli_fetch_assoc($result)) {
        echo '<tr>';
        echo '<td>' . $row['username'] . '</td>';
        echo '<td>' . date('Y-m-d H:i:s', $row['createtime']) . '</td>';
        echo '<td>' . long2ip($row['createip']) . '</td>';
        echo '<td><a href="edit.php?id=' . $row['id'] . '">编纂会员</a></td>';
        echo '<td><a href="delete.php?id=' . $row['id'] . '">删除会员</a></td>';
        echo '</tr>';
    }
    echo '<tr><td colspan="5"><a href="page.php?page=1">首页</a>  <a href="page.php?page=' . ($page - 1) . '">上一页</a>   <a href="page.php?page=' . ($page + 1) . '">下一页</a>  <a href="page.php?page=' . $total . '">尾页</a>  当前是第 ' . $page . '页  共' . $total . '页 </td></tr>';
    echo '</table>';
} else {
    echo '没有数据';
}
mysqli_close($conn);

以上内容便实现了简便的分页功效,相理解更多相关内容请拜访PHP中文网:PHP视频教程

以上就是php实现分页的道理及步骤的具体内容,更多请关注百分百源码网其它相关文章!

打赏

打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,你说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

百分百源码网 建议打赏1~10元,土豪随意,感谢您的阅读!

共有150人阅读,期待你的评论!发表评论
昵称: 网址: 验证码: 点击我更换图片
最新评论

本文标签

广告赞助

能出一分力是一分吧!

订阅获得更多模板

本文标签

广告赞助

订阅获得更多模板