本文目录一览:
php分页代码
?php
// 首页 上一页 1 2 3 4 5 下一页 末页
class StrPage{
private $file;//文件内容
private $current;//当前页
private $totalPage;//总的页数
private $url;//url地址
private $pageLen;//每页显示的内容长度
function __construct($file,$len=500){
$this-file = file_get_contents($file);
$this-current=isset($_GET['page'])?$_GET['page']:1;
$this-pageLen = $len;
$this-totalPage = $this-getTotalPage();
$this-url= $this-getUrl();
}
private function getTotalPage(){
return ceil(strlen($this-file)/$this-pageLen);
}
private function getUrl(){
$url =parse_url($_SERVER['REQUEST_URI']);
parse_str($url['query'],$queryArr);
unset($queryArr['page']);
$queryStr = http_build_query($queryArr);
return $url['path'].'?'.$queryStr.'page=';
}
private function first(){
if($this-current1)return "a href='".$this-url."1'首页/a";
}
private function pre(){
if($this-current1)return "a href='".$this-url.($this-current-1)."'上一页/a";
}
private function next(){
if($this-current$this-totalPage)return "a href='".$this-url.($this-current+1)."'下一页/a";
}
private function end(){
if($this-current$this-totalPage) return "a href='".$this-url.$this-totalPage."'末页/a";
}
private function pageList(){
for ($i=1;$i=$this-totalPage;$i++){
if($i==$this-current){
$pageListStr.="span style='font-size:20px;color:#f00'".$i."/span ";
}else{
$pageListStr.="a href='".$this-url.$i."'".$i." /a";
}
}
return $pageListStr;
}
public function pageStyle($style=1){
switch ($style){
case 1:
return "共有".$this-totalPage."页".$this-first().$this-pre().$this-pageList().$this-next().$this-end();
break;
case 2;
return $this-pageList();
break;
}
}
public function getContents(){
$prePageLen = strlen($this-subStrs($this-current-1));
$currentPageLen = strlen($this-subStrs($this-current));
return substr($this-file, $prePageLen,$currentPageLen-$prePageLen);
}
private function subStrs($page){
$len= $page*$this-pageLen;
for ($i = 0; $i $len; $i++) {
if(ord(substr($this-file,$i,1))0xa0){
$string.=substr($this-file,$i,2);
$i++;
}else{
$string.=substr($this-file,$i,1);
}
}
return $string;
}
}
$php = new StrPage('75.txt',2000);
echo "div style='font-size:14px;line-height:1.8em;color:#666;padding:6px;width:960px;height:450px;'".$php-getContents()."/div";
echo "div style='border:solid 1px #ccc;font-size:14px;color:#333'";
echo $php-pageStyle();
echo "/div";
求PHP各种分页方法,各位大仙有的别藏了~~
PHP分页方法:
第一步创建一个类 subPages.php?php
class SubPages{
private $each_disNums;//每页显示的条目数
private $nums;//总条目数
private $current_page;//当前被选中的页
private $sub_pages;//每次显示的页数
private $pageNums;//总页数
private $page_array = array();//用来构造分页的数组
private $subPage_link;//每个分页的链接
private $subPage_type;//显示分页的类型
//__construct是SubPages的构造函数,用来在创建类的时候自动运行. //@$each_disNums 每页显示的条目数 // @nums 总条目数 // @current_num 当前被选中的页 //@sub_pages 每次显示的页数 // @subPage_link 每个分页的链接 //@subPage_type 显示分页的类型 //当@subPage_type=1的时候为普通分页模式 example: 共4523条记录,每页显示10条,当前第1/453页 [首页] [上页] [下页] [尾页] //当@subPage_type=2的时候为经典分页样式 example: 当前第1/453页 [首页] [上页] 1 2 3 4 5 6 7 8 9 10 [下页] [尾页]
function __construct($each_disNums,$nums,$current_page,$sub_pages,$subPage_link,$subPage_type){
//intval通过使用特定的进制转换(默认是十进制),返回变量 var 的 integer 数值
$this-each_disNums=intval($each_disNums);
$this-nums=intval($nums);
if(!$current_page){
$this-current_page=1;
}else{
$this-current_page=intval($current_page);
}
$this-sub_pages=intval($sub_pages);
$this-pageNums=ceil($nums/$each_disNums);
$this-subPage_link=$subPage_link;
$this-show_SubPages($subPage_type);
//echo $this-pageNums."--".$this-sub_pages;
}
//__destruct析构函数,当类不在使用的时候调用,该函数用来释放资源
function __destruct(){
unset($each_disNums);
unset($nums);
unset($current_page);
unset($sub_pages);
unset($pageNums);
unset($page_array);
unset($subPage_link);
unset($subPage_type);
}
//show_SubPages函数用在构造函数里面。而且用来判断显示什么样子的分页
function show_SubPages($subPage_type){
if($subPage_type == 1){
$this-subPageCss1();
}elseif ($subPage_type == 2){
$this-subPageCss2();
}
}
//用来给建立分页的数组初始化的函数。
function initArray(){
for($i=0;$i$this-sub_pages;$i++){
$this-page_array[$i]=$i;
}
return $this-page_array;
}
//construct_num_Page该函数使用来构造显示的条目
// 即使:[1][2][3][4][5][6][7][8][9][10]
function construct_num_Page(){
if($this-pageNums $this-sub_pages){
$current_array=array();
for($i=0;$i$this-pageNums;$i++){
$current_array[$i]=$i+1;
}
}else{
$current_array=$this-initArray();
if($this-current_page = 3){
for($i=0;$icount($current_array);$i++){
$current_array[$i]=$i+1;
}
}elseif ($this-current_page = $this-pageNums $this-current_page $this-pageNums - $this-sub_pages +1 ){
for($i=0;$icount($current_array);$i++){
$current_array[$i]=($this-pageNums)-($this-sub_pages)+1+$i;
}
}else{
for($i=0;$icount($current_array);$i++){
$current_array[$i]=$this-current_page-2+$i;
}
}
}
return $current_array;
}
//构造普通模式的分页
//共4523条记录,每页显示10条,当前第1/453页 [首页] [上页] [下页] [尾页]
function subPageCss1(){
$subPageCss1Str="";
$subPageCss1Str.="共".$this-nums."条记录,";
$subPageCss1Str.="每页显示".$this-each_disNums."条,";
$subPageCss1Str.="当前第".$this-current_page."/".$this-pageNums."页 ";
if($this-current_page 1){
$firstPageUrl=$this-subPage_link."1";
$prewPageUrl=$this-subPage_link.($this-current_page-1);
$subPageCss1Str.="[a href='$firstPageUrl'首页/a] ";
$subPageCss1Str.="[a href='$prewPageUrl'上一页/a] ";
}else {
$subPageCss1Str.="[首页] ";
$subPageCss1Str.="[上一页] ";
}
if($this-current_page $this-pageNums){
$lastPageUrl=$this-subPage_link.$this-pageNums;
$nextPageUrl=$this-subPage_link.($this-current_page+1);
$subPageCss1Str.=" [a href='$nextPageUrl'下一页/a] ";
$subPageCss1Str.="[a href='$lastPageUrl'尾页/a] ";
}else {
$subPageCss1Str.="[下一页] ";
$subPageCss1Str.="[尾页] ";
}
echo $subPageCss1Str;
}
//构造经典模式的分页
//当前第1/453页 [首页] [上页] 1 2 3 4 5 6 7 8 9 10 [下页] [尾页]
function subPageCss2(){
$subPageCss2Str="";
$subPageCss2Str.="当前第".$this-current_page."/".$this-pageNums."页 ";
if($this-current_page 1){
$firstPageUrl=$this-subPage_link."1";
$prewPageUrl=$this-subPage_link.($this-current_page-1);
$subPageCss2Str.="[a href='$firstPageUrl'首页/a] ";
$subPageCss2Str.="[a href='$prewPageUrl'上一页/a] ";
}else {
$subPageCss2Str.="[首页] ";
$subPageCss2Str.="[上一页] ";
}
$a=$this-construct_num_Page();
for($i=0;$icount($a);$i++){
$s=$a[$i];
if($s == $this-current_page ){
$subPageCss2Str.="[span style='color:red;font-weight:bold;'".$s."/span]";
}else{
$url=$this-subPage_link.$s;
$subPageCss2Str.="[a href='$url'".$s."/a]";
}
}
if($this-current_page $this-pageNums){
$lastPageUrl=$this-subPage_link.$this-pageNums;
$nextPageUrl=$this-subPage_link.($this-current_page+1);
$subPageCss2Str.=" [a href='$nextPageUrl'下一页/a] ";
$subPageCss2Str.="[a href='$lastPageUrl'尾页/a] ";
}else {
$subPageCss2Str.="[下一页] ";
$subPageCss2Str.="[尾页] ";
}
echo $subPageCss2Str;
}
}
?要做分页的页面?php//每页显示的条数
$page_size=2;
//得到当前是第几页
$pageCurrent=$_GET["p"];
$offet =($pageCurrent-1)*$page_size;
//建立数据库连接
$conn = mysql_connect("地址","用户名","密码") or die("".mysql_error());
//设置字符集
mysql_query("set names gbk");
//设置数据库
mysql_select_db("数据库名",$conn) or die("".mysql_error());
if($conn) { include ("query.html");
//查询会员信息//注:这里的sql查询了两遍.第一遍是确定查询出来的总数据条数
$query_sql = "SELECT * FROM user_info_t order by id desc";//第二遍是根据需要即$page_size来确定每次查出的条数
$query_sql_sec= "SELECT * FROM user_info_t order by id desc limit $offet,$page_size";
//执行查询语句 返回一个结果集
$query_res = mysql_query($query_sql,$conn);
$query_res_sec = mysql_query($query_sql_sec,$conn);
//查询列数
//$query_cols = mysql_num_fields($query_res);
//查询行数
$query_num =mysql_num_rows($query_res);
//返回根据从结果集取得的行生成的数组,如果没有更多行
echo "table border='0' cellpadding='1' cellspacing='2' width='100%' bgcolor='#FFFFFF'";
while($query_row = mysql_fetch_array($query_res_sec)) {
echo "tr";
for ($i=0;$i$query_cols;$i++) {
echo "td bordercolor='#A2BEE1' bgcolor='#A2BEE1' width='8%'".$query_row[$i]."/td\n";
}
echo "td bordercolor='#A2BEE1' bgcolor='#A2BEE1' width='8%'";
//echo "input type='button' class='button' id='modify_record' name='modify_record' value='修改' /";
echo"button onClick=\"submit(location.href='../modify/modify.php?rec_id=$query_row[0]');\"class=\"button\";修改/button";
//echo "ahref='../delete/delete.php?rec_id=$query_row[0]'onClick=\"if(confirm('确实要删除此条记录吗?')) return true;else returnfalse;\"img src=\"../image/delete.gif\" align=\"absmiddle\"/删除/a";
echo "buttononClick=\"if(confirm('确实要删除此条记录吗?')) return submit(location.href='../delete/delete.php?rec_id=$query_row[0]');else return false;\"class=\"button\";删除/button";
echo "/td";
echo "/tr";
}
//echo "/form";
echo "/table";
require_once("../common/subPages.php");//总条目数为数据库中查询出的数据条数
$nums=$query_num;
//每次显示的页数
$sub_pages=10; //if(!$pageCurrent) $pageCurrent=1;
//调用类SubPages 传的参数为:每页显示条数/当前第几页/每次显示的页数/分页模式
$subPage=new SubPages($page_size,$nums,$pageCurrent,$sub_pages,"query.php?p=",1);
}else{
die('数据库连接异常: '.mysql_error());
}
//断开数据库连接
if ($conn)
{
mysql_close($conn);
}
?
php分页功能怎么实现
php本身是没有分页概念的,分页是URL传参,然后通过mysql查询语句到数据库获取数据,然后实现的分页,url上的参数,通过PHP的$_GET都是可以获取到的。
现在市面上的PHP框架基本都有PHP分页类,参照文档直接调用就好了,如果想看实现过程,可以去下载一个TP框架,然后打开里面的分页类查看里面的源代码。
php分页代码 怎么写
Web开发是今后分布式程式开发的主流,通常的web开发都要涉及到与数据库打交道,客户端从服务器端读取通常都是以分页的形式来显示,一页一页的阅读起来既方便又美观。所以说写分页程序是web开发的一个重要组成部分,在这里,我们共同来研究分页程序的编写。
一、分页程序的原理
分页程序有两个非常重要的参数:每页显示几条记录($pagesize)和当前是第几页($page)。有了这两个参数就可以很方便的写出分页程序,我们以MySql数据库作为数据源,在mysql里如果要想取出表内某段特定内容可以使用的 T-SQL语句:select * from table limit offset,rows来实现。这里的offset是记录偏移量,它的计算方法是offset=$pagesize*($page-1),rows是要显示的记录条数,这里就是$page。也就是说select * from table limit 10,10这条语句的意思是取出表里从第11条记录开始的20条记录。
二、主要代码解析
$pagesize=10; //设置每一页显示的记录数
$conn=mysql_connect("localhost","root",""); //连接数据库
$rs=mysql_query("select count(*) from tb_product",$conn); //取得记录总数$rs
$myrow = mysql_fetch_array($rs);
$numrows=$myrow[0];
//计算总页数
$pages=intval($numrows/$pagesize);
//判断页数设置
if (isset($_GET['page'])){
$page=intval($_GET['page']);
}
else{
$page=1; //否则,设置为第一页
}
三、创建用例用表myTable
create table myTable(id int NOT NULL auto_increment,news_title varchar(50),news_cont text,add_time datetime,PRIMARY KEY(id))
四、完整代码
<html>
<head>
<title>php分页示例</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
</head>
<body>
<?php
$conn=mysql_connect("localhost","root","");
//设定每一页显示的记录数
$pagesize=1;
mysql_select_db("mydata",$conn);
//取得记录总数$rs,计算总页数用
$rs=mysql_query("select count(*) from tb_product",$conn);
$myrow = mysql_fetch_array($rs);
$numrows=$myrow[0];
//计算总页数
$pages=intval($numrows/$pagesize);
if ($numrows%$pagesize)
$pages++;
//设置页数
if (isset($_GET['page'])){
$page=intval($_GET['page']);
}
else{
//设置为第一页
$page=1;
}
//计算记录偏移量
$offset=$pagesize*($page - 1);
//读取指定记录数
$rs=mysql_query("select * from myTable order by id desc limit $offset,$pagesize",$conn);
if ($myrow = mysql_fetch_array($rs))
{
$i=0;
?>
<table border="0" width="80%">
<tr>
<td width="50%" bgcolor="#E0E0E0">
<p align="center">标题</td>
<td width="50%" bgcolor="#E0E0E0">
<p align="center">发布时间</td>
</tr>
<?php
do {
$i++;
?>
<tr>
<td width="50%"><?=$myrow["news_title"]?></td>
<td width="50%"><?=$myrow["news_cont"]?></td>
</tr>
<?php
}
while ($myrow = mysql_fetch_array($rs));
echo "</table>";
}
echo "<div align='center'>共有".$pages."页(".$page."/".$pages.")";
for ($i=1;$i< $page;$i++)
echo "<a href='fenye.php?page=".$i."'>[".$i ."]</a> ";
echo "[".$page."]";
for ($i=$page+1;$i<=$pages;$i++)
echo "<a href='fenye.php?page=".$i."'>[".$i ."]</a> ";
echo "</div>";
?>
</body>
</html>
五、总结
本例代码在windows2000 server+php4.4.0+mysql5.0.16上运行正常。该示例显示的分页格式是[1][2][3]…这样形式。假如想显示成“首页 上一页 下一页 尾页”这样形式,请加入以下代码:
$first=1;
$prev=$page-1;
$next=$page+1;
$last=$pages;
if ($page > 1)
{
echo "<a href='fenye.php?page=".$first."'>首页</a> ";
echo "<a href='fenye.php?page=".$prev."'>上一页</a> ";
}
if ($page < $pages)
{
echo "<a href='fenye.php?page=".$next."'>下一页</a>
echo "<a href='fenye.php?page=".$last."'>尾页</a> ";
}
其实,写分页显示代码是很简单的,只要掌握了它的工作原理。希望这篇文章能够带给那些需要这方面程序web程序员的帮助。
php 分页类怎么用啊?
?php
class Page {
private $total_rows;//数据库总条数
private $per_page_rows;//每页显示条数
private $limit;
private $uri;
private $total_pages;//总页数
private $config=array("header"="记录条数","prev"="上一页","next"="下一页","first"="首 页","last"="尾 页");
private $list_length=8;
public function __construct($total_rows,$per_page_rows=10,$url_args){
$this-total_rows=$total_rows;
$this-per_page_rows=$per_page_rows;
$this-uri=$this-get_uri($url_args);
$this-page = !empty($_GET['page']) ? $_GET['page'] : 1;
$this-total_pages=ceil($this-total_rows/$this-per_page_rows);
$this-limit=$this-set_limit();
}
private function set_limit() {
return "limit ".($this-page-1)*$this-per_page_rows.",{$this-per_page_rows}";
}
private function get_uri($url_args) {
$url=$_SERVER["REQUEST_URI"].(strpos($_SERVER["REQUEST_URI"],"?") ? "" : "?").$url_args;
$parse=parse_url($url);
if (isset($parse['query'])) {
parse_str($parse['query'],$params);//把url字符串解析为数组
unset($params['page']);//删除数组下标为page的值
$url=$parse['path'].'?'.http_build_query($params);//再次构建url
}
return $url;
}
public function __get($args) {
if ($args=="limit") {
return $this-limit;
}else{
return null;
}
}
private function start_page(){
if ($this-total_rows==0) {
return 0;
}else{
return (($this-page-1)*$this-per_page_rows)+1;
}
}
private function end_page(){
return min($this-page*$this-per_page_rows,$this-total_rows);
}
private function go_first() {
$html="";
if ($this-page==1) {
$html.="nbsp;{$this-config['first']}nbsp;";
}else{
$html.="nbsp;a href='{$this-uri}page=1'{$this-config['first']}/anbsp;";
}
return $html;
}
private function go_prev() {
$html="";
if ($this-page==1) {
$html.="nbsp;{$this-config['prev']}nbsp;";
}else{
$html.="nbsp;a href='{$this-uri}page={$this-page}-1'{$this-config['prev']}/anbsp;";
}
return $html;
}
private function go_next() {
$html="";
if ($this-page==$this-total_pages) {
$html.="nbsp;{$this-config['next']}nbsp;";
}else{
$html.="nbsp;a href='{$this-uri}page={$this-page}+1'{$this-config['next']}/anbsp;";
}
return $html;
}
private function go_last() {
$html="";
if ($this-page==$this-total_pages) {
$html.="nbsp;{$this-config['last']}nbsp;";
}else{
$html.="nbsp;a href='{$this-uri}page={$this-total_pages}'{$this-config['last']}/anbsp;";
}
return $html;
}
private function go_page() {
return 'nbsp;input type="text" onkeydown="javascript:if(event.keyCode==13){var page=(this.value'.$this-total_pages.')?'.$this-total_pages.':this.value;location=\''.$this-uri.'page=\'+page+\'\'}" value="'.$this-page.'" style="width:25px;" /input type="button" onclick="javascript:var page=(this.previousSibling.value'.$this-total_pages.')?'.$this-total_pages.':this.previousSibling.value;location=\''.$this-uri.'page=\'+page+\'\'" value="GO" /nbsp;';
}
private function page_list() {
$link_page="";
$i_num=floor($this-list_length/2);
for ($i = $i_num; $i = 1; $i--) {
$page=$this-page-$i;
if ($page1) {
continue;
}else{
$link_page.="nbsp;a href='{$this-uri}page={$page}'{$page}/anbsp;";
}
}
$link_page.="nbsp;{$this-page}nbsp;";
for ($i = 1; $i $i_num; $i++) {
$page=$this-page+$i;
if ($page=$this-total_pages) {
$link_page.="nbsp;a href='{$this-uri}page={$page}'{$page}/anbsp;";
}else{
break;
}
}
return $link_page;
}
public function out_page($display=array(0,1,2,3,4,5,6,7,8)) {
$display_html='';
$html[0]="nbsp;共有b{$this-total_rows}/b{$this-config['header']}nbsp;";
$html[1]="nbsp;每页显示b".($this-end_page()-$this-start_page()+1)."/b条,本页显示从b{$this-start_page()}/b--b{$this-end_page()}/b{$this-config['header']}nbsp;";
$html[2]="nbsp;b{$this-page}/b/b{$this-total_pages}/b页nbsp;";
$html[3]=$this-go_first();
$html[4]=$this-go_prev();
$html[5]=$this-page_list();
$html[6]=$this-go_next();
$html[7]=$this-go_last();
$html[8]=$this-go_page();
foreach ($display as $index){
$display_html.=$html[$index];
}
return $display_html;
}
}
?