完美分页

<?php
header("Content-Type:text/html;charset=utf-8");
class Page {
		private $total; //数据表中总记录数
		private $listRows; //每页显示行数
		private $limit;
		private $uri;
		private $pageNum; //页数
		private $config=array(‘header‘=>"个记录", "prev"=>"上一页", "next"=>"下一页", "first"=>"首 页", "last"=>"尾 页");
		private $listNum=8;
		/*
		 * $total
		 * $listRows
		 */
		public function __construct($total, $listRows=10, $pa=""){
			$this->total=$total;
			$this->listRows=$listRows;
			$this->uri=$this->getUri($pa);
			$this->page=!empty($_GET["page"]) ? $_GET["page"] : 1;
			$this->pageNum=ceil($this->total/$this->listRows);
			$this->limit=$this->setLimit();
		}

		private function setLimit(){
			return "Limit ".($this->page-1)*$this->listRows.", {$this->listRows}";
		}

		private function getUri($pa){
			$url=$_SERVER["REQUEST_URI"].(strpos($_SERVER["REQUEST_URI"], ‘?‘)?‘‘:"?").$pa;
			echo $url;
			$parse=parse_url($url);

			if(isset($parse["query"])){
				parse_str($parse[‘query‘],$params);
				unset($params["page"]);
				$url=$parse[‘path‘].‘?‘.http_build_query($params);

			}

			return $url;
		}

		private function __get($args){
			if($args=="limit")
				return $this->limit;
			else
				return null;
		}

		private function start(){
			if($this->total==0)
				return 0;
			else
				return ($this->page-1)*$this->listRows+1;
		}

		private function end(){
			return min($this->page*$this->listRows,$this->total);
		}

		private function first(){
			if($this->page==1)
				$html.=‘‘;
			else
				$html.="  <a href=‘{$this->uri}&page=1‘>{$this->config["first"]}</a>  ";

			return $html;
		}

		private function prev(){
			if($this->page==1)
				$html.=‘‘;
			else
				$html.="  <a href=‘{$this->uri}&page=".($this->page-1)."‘>{$this->config["prev"]}</a>  ";

			return $html;
		}

		private function pageList(){
			$linkPage="";

			$inum=floor($this->listNum/2);

			for($i=$inum; $i>=1; $i--){
				$page=$this->page-$i;

				if($page<1)
					continue;

				$linkPage.=" <a href=‘{$this->uri}&page={$page}‘>{$page}</a> ";

			}

			$linkPage.=" {$this->page} ";

			for($i=1; $i<=$inum; $i++){
				$page=$this->page+$i;
				if($page<=$this->pageNum)
					$linkPage.=" <a href=‘{$this->uri}&page={$page}‘>{$page}</a> ";
				else
					break;
			}

			return $linkPage;
		}

		private function next(){
			if($this->page==$this->pageNum)
				$html.=‘‘;
			else
				$html.="  <a href=‘{$this->uri}&page=".($this->page+1)."‘>{$this->config["next"]}</a>  ";

			return $html;
		}

		private function last(){
			if($this->page==$this->pageNum)
				$html.=‘‘;
			else
				$html.="  <a href=‘{$this->uri}&page=".($this->pageNum)."‘>{$this->config["last"]}</a>  ";

			return $html;
		}

		private function goPage(){
			return ‘  <input type="text" onkeydown="javascript:if(event.keyCode==13){var page=(this.value>‘.$this->pageNum.‘)?‘.$this->pageNum.‘:this.value;location=\‘‘.$this->uri.‘&page=\‘+page+\‘\‘}" value="‘.$this->page.‘" style="width:25px"><input type="button" value="GO" onclick="javascript:var page=(this.previousSibling.value>‘.$this->pageNum.‘)?‘.$this->pageNum.‘:this.previousSibling.value;location=\‘‘.$this->uri.‘&page=\‘+page+\‘\‘">  ‘;
		}
		function fpage($display=array(0,1,2,3,4,5,6,7,8)){
			$html[0]="  共有<b>{$this->total}</b>{$this->config["header"]}  ";
			$html[1]="  每页显示<b>".($this->end()-$this->start()+1)."</b>条,本页<b>{$this->start()}-{$this->end()}</b>条  ";
			$html[2]="  <b>{$this->page}/{$this->pageNum}</b>页  ";

			$html[3]=$this->first();
			$html[4]=$this->prev();
			$html[5]=$this->pageList();
			$html[6]=$this->next();
			$html[7]=$this->last();
			$html[8]=$this->goPage();
			$fpage=‘‘;
			foreach($display as $index){
				$fpage.=$html[$index];
			}

			return $fpage;

		}

	}

      $link=mysql_connect("localhost", "root", "123456");

	mysql_select_db("xsphpdb");

	$result=mysql_query("select * from shops");

	$total=mysql_num_rows($result);

	$num=5;

	$page=new Page($total, $num, "&cid=99");

	$sql="select * from shops {$page->limit}";

	$result=mysql_query($sql);

	echo ‘<table align="center" border="1" width="960">‘;
	echo ‘<caption><h1>SHOPS</h1></caption>‘;

	while($row=mysql_fetch_assoc($result)){
		echo ‘<tr>‘;
		echo ‘<td>‘.$row["id"].‘</td>‘;
		echo ‘<td>‘.$row["name"].‘</td>‘;
		echo ‘<td>‘.$row["price"].‘</td>‘;
		echo ‘<td>‘.$row["num"].‘</td>‘;
		echo ‘<td>‘.$row["desn"].‘</td>‘;
		echo ‘</tr>‘;
	}

	echo ‘<tr><td colspan="5" align="right">‘.$page->fpage(array(8,3,4,5,6,7,0,1,2)).‘</td></tr>‘;
	echo ‘</table>‘;

?>

完美分页,布布扣,bubuko.com

时间: 2024-12-25 17:08:47

完美分页的相关文章

封装的完美分页类

<?php /** file: page.class.php 完美分页类 Page */ class Page { private $total; //数据表中总记录数 private $listRows; //每页显示行数 private $limit; //SQL语句使用limit从句,限制获取记录个数 private $uri; //自动获取url的请求地址 private $pageNum; //总页数 private $page; //当前页 private $config = arr

完美分页类

1 <?php 2 header("Content-Type:text/html;charset=utf-8"); 3 //加载分页类 4 include "page.class.php"; 5 6 //定义总数 7 $total =0; 8 9 //1.造连接对象 10 $db = new mysqli("localhost","root","123","mydb"); 11 1

MySQL完美分页

自己学的MySQL完美分页,觉得以后用的着就写篇博客 输出效果图:(没有进行美化) 先在根目录下建立demo.php 和 page.class.php两个文件(demo.php为测试文件,page.class.php为分页类文件) 在数据库中建立自己相应的表,这里以sqldb库和shops表为例 </pre><p><span style="font-size:12px"><img src="http://img.blog.csdn.n

php完美分页工具

<?php /** file: page.class.php 完美分页类 Page */ class Page { private $total; //数据表中总记录数 private $listRows; //每页显示行数 private $limit; //SQL语句使用limit从句,限制获取记录个数 private $uri; //自动获取url的请求地址 private $pageNum; //总页数 private $page; //当前页 private $config = arr

完美分页代码

<?php /** file: page.class.php 完美分页类 Page */ class Page { private $total; //数据表中总记录数 private $listRows; //每页显示行数 private $limit; //SQL语句使用limit从句,限制获取记录个数 private $uri; //自动获取url的请求地址 private $pageNum; //总页数 private $page; //当前页 private $config = arr

完美分页类设计--细说PHP

完美分页类page.class.php,敲完了代码,测试的时候发现一片空白完全没东西输出来,可是代码又没有显示报错,最后只能照着源码一行行的对,发现原来少了个“.”,但是这个 . 是被单引号括起来,被单纯的当做了字符串来看待,所以没有报错.整整用了2个多小时去核对整理自己思路,看代码.因此,细心对于刚开始学PHP参考着源码来敲代码很重要.当我把 . 补齐了,可是效果并不是如下.而是:完全没有分页结构的信息.我显示反复对了好多次分页结构的方法fpage()的代码,都没有感觉都没有问题.当时我代码第

PHP 完美分页

首先一个分页类,如下(摘自网络)可拷贝直接使用 <?php /* * Created on 2013-12-3 * 分页类 * To change the template for this generated file go to * Window - Preferences - PHPeclipse - PHP - Code Templates */ class Pagination { private $each_disNums; //每页显示的条目数 private $nums; //总

php分页

第一个页面page.class.php(此页面相当于工具) <?php /** file: page.class.php 完美分页类 Page */ class Page { private $total; //数据表中总记录数 private $listRows; //每页显示行数 private $limit; //SQL语句使用limit从句,限制获取记录个数 private $uri; //自动获取url的请求地址 private $pageNum; //总页数 private $pag

11月3日下午数据库的封装和引用 数据的分页

一.数据库的封装和引用 之前写代码都是通过mysql取结果写的,这样写的缺点是每次要用数据时都需要写sql参数,并且要写很多份,而且当数据库换了,或者密码改了就需要修改每一个文件里的和mysql有关的参数,结果会很复杂.下面就把数据库的操作封装成一个类,每一次操作的时候去调用封装的类. 以后就用封装类的方法写,防止换数据库.换电脑.或者是放到服务器上以后直接从封装的类里面更改数据库名称,用户名.密码等.就不需要改页面里的内容了. 1.查询语句 第1步:建一个封装类的文件DBDA.class.ph