php之分页种代码

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBオリジナル
2016-06-13 11:09:11792ブラウズ

php之分页类代码

/*思路1.把地址栏的URL获取2.分析URL中的query部分--就是?后面传参数的部分3.query部分分析成数组4.把数组中的page单元,+1,-1,形成2个新的数组5.再把新数组拼接成query部分,合成上一页,下一页连接地址*///分页类class Page {	public $total;	//全部条数,从数据库取出	public $prePage = 10; //每页的条数	protected $curr= 1;	//默认当前页码	public function __construct($total,$prePage='') {		$this->total = $total; //把总条目信息放在total属性		if ($prePage > 0) {			$this->prePage = $prePage;	//把每页数量放在perPage属性		}		//计算当前页码		if (isset($_GET['page']) && ($_GET['page'] + 0) > 0) {			$this->curr = $_GET['page'] + 0;		}	}	//主体函数	public function showPage() {		if ($this->total <=0) {			return ''; //如果总条目<=0 直接返回空字符串		}		$cnt = ceil($this->total / $this->prePage); //算总页数,进一取整			//根据当前页,算上一页,下一页		/*		分析url,有几种情况?		xx.php		xx.php?id=5		xx.php?page=3		xx.php?id=5&page=3		*/				//最终生成的URL里边必然有page=N		$url = $_SERVER['REQUEST_URI'];		$parse = parse_url($url); //把URL分析结果放在数组里		//print_r($parse);		//保证参数里边有page		if (!isset($parse['query'])) {			$parse['query'] = 'page=' .$this->curr;		}		//把query字符串分析成数组,再次确保有page选项		parse_str($parse['query'],$parms);		if (!array_key_exists('page', $parms)) {			$parms['page'] = $this->curr;		}		//上边四种情况都测试一遍,page参数都能生成		//print_r($parms);		//判断除了page之外,还有没有其他参数		if (count($parms) == 1) {			$url = $parse['path'] . '?';		} else {			unset($parms['page']);			$url = $parse['path'] . '?' . http_build_query($parms) . '&';		}		//echo $url		$prev = $this->curr - 1;		$next = $this->curr + 1;		//首页		$indexLink = '<a href="' . $url .'page=' . 1 . '">首页</a>';		//上一页		if ($prev < 1) {			$prevLink = '';		}else {			$prevLink = '<a href="' . $url .'page=' . $prev . '">上一页</a>';		}		//下一页		if ($next > $cnt) {			$nextLink = '';		}else {			$nextLink = '<a href="' . $url .'page=' . $next . '">下一页</a>';		}		//尾页		$lastLink = '<a href="' . $url .'page=' . $cnt . '">尾页</a>';		//echo $indexLink.'  '.$prevLink.'  '.$nextLink .'  '.$lastLink;		//上一页,1 2 3 4 5 下一页		$start = $this->curr - (5-1)/2; //计算左侧开始的页码		$end = $this->curr + (5-1)/2;	//计算右侧开始的页码				//如果左侧的页面,已经小于1,则把小于1 的部分补到右侧		if ($start < 1) {			$end += (1 - $start);			$start = 1; //修改start = 1					if ($end > $cnt) {				$end  = $cnt;			}		}		//把右侧超出的部分,补到左边		if ($end > $cnt) {			$start -= ($end - $cnt);			$end = $cnt;			if ($start < 1) {				$start = 1;			}		}				//循环出页码数		$pageStr = '';		for ($i=$start; $i <= $end ; $i++) { 							if ($i == $this->curr) {				$pageStr .= $i;				continue;			}			$pageStr .= '<a href="' . $url . 'page=' . $i . '">' . $i . '</a>';		}		return $indexLink.$prevLink.$pageStr.$nextLink.$lastLink;	}}$page = new Page(30,3);echo $page->showPage();

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。