-
PHP简单分页函数代码总结
在我做过这么多的php开发了我发现两种分页类型,一种分页是直接把数据库连接与分页连接在了一起,另外一种分页函数只有分页的逻辑判断并没有数据库的参与了,后者更好维护与重复使用一些,前者维护麻烦不好重复利用,下面我都给大家整理几个例子.
例子一,这个分页函数就有连接数据库再查看,代码不详细解说了,注释里有:
- <?php
- //page当前页,num每页的页数
- $page=isset($_GET['page'])?intval($_GET['page']):1;
- $num=5;
- $conn = mysql_connect('127.0.0.1','root','');
- if (!$conn) {
- die('Could not connect:'.mysql_error());
- }
- mysql_select_db('shop');
- //获取记录总数
- $total=mysql_num_rows(mysql_query("select * from user"));
- //计算页数
- $pagenum=ceil($total/$num);
- //限制页数不能超出范围
- If($page>$pagenum || $page == 0){
- Echo 'Error : Can Not Found The page.';
- Exit;
- }
- //语句“Select * from table limit 0,10”从table表提取十条信息,0为起点,10为提取的数目
- //$offset为起点值,如当前页为第一页,每页5条,起点即为0,同理当前为第二页,起点将为5
- $offset=($page-1)*$num;
- $result=mysql_query("select * from user limit $offset,$num");
- while($it=mysql_fetch_array($result)){
- echo 'id:'.$it['id'].' name:'.$it['name'].'<br />';
- }
- //显示链接页面切换链接,当前页无链接
- for($i=1;$i<=$pagenum;$i++){
- $show=($i!=$page)?"<a href='index.php?page=".$i."'>$i</a>":"<b>$i</b>";
- echo $show." ";
- }
- echo $total.'条记录,每页5条,共'.$pagenum.'页';
- mysql_free_result($result);
- mysql_close($conn);
- ?>
例子二,直接的把分页代码逻辑提出来,重复利用比较好,代码如下:
- <?php
- /*
- #函数:csPage
- #功能:返回页面列表
- */
- Function csPage($iPage,$aPage,$urlStart,$urlEnd){
- $tmp = "";
- if($iPage == 1 && $aPage == 1){
- $tmp = "<strong> 1/1 </strong>";
- }else{
- if($iPage == 1){
- $tmp = "<span> |< </span><span> << </span>";
- }else{
- $tmp = '<a title="首页" href="' . $UrlStart . 1 . $urlEnd . '"> |< </a><a title="上一页" href="' . $UrlStart . ($iPage-1) . $urlEnd . '"> << </a>';
- }
- $tmp .= "<strong> " . $iPage . "/" . $aPage . " </strong>";
- if($iPage == $aPage){
- $tmp .= '<span> >> </span><span> >| </span>';
- }else{
- $tmp .= '<a title="下一页" href="' . $urlStart . ($iPage+1) . $urlEnd .' "> >> </a><a title="尾页" href="' . $urlStart . $aPage . $urlEnd . '"> >| </a>';
- }
- }
- return $tmp;
- }
- ?>
总结一下:如果让我们选择可能我会选择第二种方法这样维护好实现方法简单,第一种分页适合初学者合适简单但维护复杂.
出处:http://www.phpfensi.com/php/20140618/3385.html
栏目列表
最新更新
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
Python初学者友好丨详解参数传递类型
如何有效管理爬虫流量?
SQL SERVER中递归
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
这是目前我见过最好的跨域解决方案!
减少回流与重绘
减少回流与重绘
如何使用KrpanoToolJS在浏览器切图
performance.now() 与 Date.now() 对比
一款纯 JS 实现的轻量化图片编辑器
关于开发 VS Code 插件遇到的 workbench.scm.
前端设计模式——观察者模式
前端设计模式——中介者模式
创建型-原型模式