ホームページ >バックエンド開発 >PHPチュートリアル >PHP ページネーター プログラム コード_PHP チュートリアル

PHP ページネーター プログラム コード_PHP チュートリアル

WBOY
WBOYオリジナル
2016-07-13 10:43:541157ブラウズ

この記事では、ページネーターのPHPページングプログラムコードを紹介します。必要な友達は参考のために入力してください。

コードは次のとおりです コードをコピー

クラスのページネーター {

関数 __construct () {

}

静的関数 render($page_type, array $args = array()) {
$html = ''; スイッチ ($page_type)
                                                                   ケース '1':
$html = page_1($channel_code, $page_num, $cur_page, $per_group, $base_url, $n, $v); 休憩
ケース '2':
$ html = fpage($ row_num、$ pagesize、$ page、$ url); 休憩
ケース「3」:
休憩

デフォルト:
$html = page($num, $perpage, $curpage, $mpurl, $hiddenFrom=''); }

$html を返します。 }



//機能 1: 総ページ数、現在のページ、ページ グループ、URL に基づいてページング ナビゲーションを生成します
関数 page_1($channel_code, $page_num, $cur_page, $per_group, $base_url, $n, $v) {
//ページング関数パラメータリスト (ページ数、現在のページ、ページごとの数、リンクアドレス)
$base_url .= strpos($base_url, '?') ? '&' : '?'; // ?がある場合は & を追加、そうでない場合は ? を追加します。

$page_val = "";
if ($page_num < 1) {
return $page_val // 1 未満の場合は空を返します
; } elseif ($page_num == 1) {
$ page_val = 1を返します。 }

//グループ

$group_ok = !(($page_num-1) % ($per_group-1)) //剰余なし
// 合計でグループが何個あるかを計算します
If($group_ok) {
$group_num = ($page_num-1)/($per_group-1); }else {
$group_num = ceil(($page_num-1) / ($per_group-1)); } //現在のページがグループ内の最後のページかどうかを判断します


//グループの数
$is_last_page = !(($cur_page-1) % ($per_group-1)) //現在
に含まれるグループの数を計算します。 if ($is_last_page) {
$cur_group = ($cur_page-1) / ($per_group-1) + 1; } else {
$cur_group = ceil(($cur_page-1) / ($per_group-1)); }

// 表示される開始ページ、このキーを計算します
$from = ($cur_group - 1) * ($per_group-1) + 1; $from = $cur_group <= 1 :$from;
$to = $from + $per_group; $to = $to > $page_num + 1 : $to;
for($a = $from; $a < $to; $a++) {
If ($a != $cur_page) {

//現在のページではありません
$page_val .= '
  • ' . $a . '
  • ';
                                                                                             //現在のページ
    $page_val .='
  • '. $a .'
  • ';                                                                                }

    //前のページ次のページホームページ最後のページ
    $next = $cur_page + 1; $prev = $cur_page-1 //現在のページ-1
    ;
    If ($cur_page != $page_num) {
    // 現在のページは最後のページではありません
    $page_val .= '' . '次のページ' . ';
    $page_val .= '' . '>>'; //最後のページ
    }
    If ($cur_page != 1){

    //最初のページではなく、前のコンテンツを追加します
    $page_val = '
    ' . '前のページ' . '
    '
    $page_val = ' ' . '<<' ''
    }
    $page_val = '';

    $page_val を返す
    }




    // 機能 2: レコード数、ページリスト、現在のページ、URL 年に基づいてページを複数のページに分割します
    関数 fpage($row_num, $pagesize, $page, $url) {
    //$page、現在のページ; $row_num レコードの総数; $pagesize: ページごとのレコード数
    //もし、計算がある場合は1を足します
    $page_count = $row_num % $pagesize?intval($row_num / $pagesize) + 1:intval($row_num / $pagesize);
    if ($page_count == 1) {
    $page_string = "最初のページ|前のページ|次のページ|最後のページ"; } else {
    //ページが複数ある場合
    if ($page == 1) {
    //最初のページには
    が表示されます $page_string = "
    最初のページ| 次のページ| 最後のページ";                                                                                If (($page > 1) and ($page $page_string = " 最初のページ | 前のページ| 次のページ| 最後のページ                                                                                if ($page == $page_count) {
    $page_string = " 最初のページ | 前のページ|次のページ| 最後のページ";                                                                                }
    $page_str = $page_string . ("," . $page . "/" . $page_count . "ページ"); echo "

    "

    "; }


    /**
    *ページング機能
    *
    * @param int $num: レコードの総数
    * @param int $perpage: ページごとのレコード数
    * @param int $curpage: 現在のページ
    * @param string $mpurl: パス URL
    * @param 不明なタイプ $hiddenFrom
    * @return 文字列
    ​*/
    関数ページ($num, $perpage, $curpage, $mpurl,$hiddenFrom='') {
    $multipage = ''; //復元
    $mpurl .= strpos($mpurl, '?') '&' : '?';
    If($num > $perpage) {
    $ページ = 10; $offset = 2;
    $pages = @ceil($num / $perpage) //総ページ数
    ;
    If($page > $pages) {
    $from = 1; $to = $ページ;                                                                                          // 総ページ数 > 10 の場合
    $from = $curpage - $offset; $to = $from + $page - 1;
    If($from
    $to = $curpage + 1 - $from; $から = 1;                     if($to - $from < $page) {
    $to = $page;
    }
    } elseif($to > $pages) {
                        $from = $pages - $page + 1;
                        $to = $pages;
                    }
                }
     
                if ($hiddenFrom) {
                    $multipage = ($curpage - $offset > 1 && $pages > $page ? '首页 ' : '').
                    ($curpage > 1 ? ' ‹‹上一页 ' : '');
                    for($i = $from; $i <= $to; $i++) {
                        $multipage .= $i == $curpage ? ''.$i.' ' :
                        ''.$i.' ';
                    }
     
                    $multipage .= ($curpage < $pages ? '下一页››' : '').
                    ($to < $pages ? ' 末页' : '');
                    $multipage = $multipage ? '
    '.$multipage.'
    ' : '';
                } その他 {
     
                    $multipage = ($curpage - $offset > 1 && $pages > $page ? '首页 ' : '') 。
                    ($curpage > 1 ? ' ‹‹上一页 ' : '') ;
     
                    for($i = $from; $i                     $multipage .= $i == $curpage ? ''.$i.' ':
                        ''.$i.' ';
                    }
     
                    $multipage .= ($curpage < $pages ? '下一页›› ':'')。
                    ($to < $pages ? ' 末页' : '');
                    $multipage = $multipage ? '
    '.$multipage.'
    ' : '';
                }
            }
            $multipage を返します。
        }
        //暂不用
        関数 page_get_start($page, $ppp, $totalnum) {
            $totalpage = ceil($totalnum / $ppp);
            $page = max(1, min($totalpage, intval($page)));
            return ($page - 1) * $ppp;
        }
        //暂不用
        関数 js_page($hiddenFrom,$page)
        {
            if ($hiddenFrom) {
                return ' onclick=javascript:$("#page").val("'.$page.'");$("#'.$hiddenFrom.'").submit(); ';
            }
        }
    }
     
     
     
    ?>

    www.bkjia.comtru​​ehttp://www.bkjia.com/PHPjc/633149.html技術記事この文章は、一般的なページネーターの php プログラム コードであり、必要な友人が参照できるようになっています。
    声明:
    この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。