ホームページ  >  記事  >  バックエンド開発  >  PHP はページ番号の範囲に自動的に適応します ページング プログラム_PHP チュートリアル

PHP はページ番号の範囲に自動的に適応します ページング プログラム_PHP チュートリアル

WBOY
WBOYオリジナル
2016-07-21 14:57:511021ブラウズ

效果图:
 
记得以前看到过一个页码方式的分页效果,页码数多了折行继续显示一直到60多页,呵呵!有点影响美观!

于是写了一个,可以自动适应范围的页码分页程序
也就是说,页码格式如下
<< < 1 2 3 4 5 6 7 > >>
<< < 6 7 8 9 10 11 12 > >>

下划线为当前页,这样就可以固定显示一个相近的页码,避免太长影响美观
代码加了注释,主要是新手看看,呵呵 ,写这个函数,没有考虑表现结构分离问题,高手就不要追究了!

function page($page,$total,$phpfile,$pagesize=10,$pagelen=7){
$pagecode = '';//定义变量,存放分页生成的HTML
$page = intval($page);//避免非数字页码
$total = intval($total);//保证总记录数值类型正确
if(!$total) return array();//总记录数为零返回空数组
$pages = ceil($total/$pagesize);//计算总分页
//处理页码合法性
if($page<1) $page = 1;
if($page>$pages) $page = $pages;
//计算查询偏移量
$offset = $pagesize*($page-1);
//页码范围计算
$init = 1;//起始页码数
$max = $pages;//结束页码数
$pagelen = ($pagelen%2)?$pagelen:$pagelen+1;//页码个数
$pageoffset = ($pagelen-1)/2;//页码个数左右偏移量

//生成html
$pagecode='
';
$pagecode.="$page/$pages";//第几页,共几页
//如果是第一页,则不显示第一页和上一页的连接
if($page!=1){
$pagecode.="<<";//第一页
$pagecode.="<";//上一页
}
//分页数大于页码个数时可以偏移
if($pages>$pagelen){
//如果当前页小于等于左偏移
if($page<=$pageoffset){
$init=1;
$max = $pagelen;
}else{//如果当前页大于左偏移
//如果当前页码右偏移超出最大分页数
if($page+$pageoffset>=$pages+1){
$init = $pages-$pagelen+1;
}else{
//左右偏移都存在时的计算
$init = $page-$pageoffset;
$max = $page+$pageoffset;
}
}
}
//生成html
for($i=$init;$i<=$max;$i++){
if($i==$page){
$pagecode.=''.$i.'';
} else {
$pagecode.="$i";
}
}
if($page!=$pages){
$pagecode.=">";//下一页
$pagecode.=">>";//最后一页
}
$pagecode.='
';
return array('pagecode'=>$pagecode,'sqllimit'=>' limit '.$offset.','.$pagesize);
}
?>



関数パラメータ:

$page $_GETで取得した現在のページ番号
$total 総レコード数
$phpfile ページ番号 接続ファイル名
$pagesize 説明の必要はありませんね(笑)
$pagelen 最大数表示するページ番号のメモ (奇数)、対称!
関数は配列を返します:
pagecode インデックスは生成された HTML コードに対応します
sqllimit インデックスは SQL 制限サフィックスに対応します

使用方法:

CSS
$phpfile = 'index.php';
$page= isset($_GET['page'])?$_GET['page']:1;
$db = new Mysql(); $counts = $db->counts('test` から `id` を選択');
$sql='`test` から `id`,`title` を選択'
$getpageinfo = page($page, $counts,$phpfile);
$sql.=$getpageinfo['sqllimit'];
$data = $db->getRows($sql);
echo $getpageinfo[' pagecode'];// ページングの HTML コードを表示します
?>









合計 2 ページ: 前のページ
1

    2
  • 次のページ
  • http://www.bkjia.com/PHPjc/363989.html
  • www.bkjia.com
本当

http://www.bkjia.com/PHPjc/363989.html技術記事レンダリング: ページ数が多すぎると、60 ページを超えるまで改行が表示され続けるというページ番号の影響を以前見たことがあります。見た目にも少し影響しますよ! それで私はそれを書きました、あなたは...
声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。