ホームページ > バックエンド開発 > PHPチュートリアル > このようなページング クラスがありますが、どうすれば機能するでしょうか?

このようなページング クラスがありますが、どうすれば機能するでしょうか?

WBOY
リリース: 2016-06-23 14:09:15
オリジナル
940 人が閲覧しました

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){      $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;$i<count($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;$i<count($current_array);$i++){         $current_array[$i]=($this->pageNums)-($this->sub_pages)+1+$i;         }        }else{         for($i=0;$i<count($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;$i<count($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   require_once("SubPages.php");   //每页显示的条数     $page_size=20;   //总条目数     $nums=1024;   //每次显示的页数     $sub_pages=10;   //得到当前是第几页     $pageCurrent=$_GET["p"];     //if(!$pageCurrent) $pageCurrent=1;           $subPages=new SubPages($page_size,$nums,$pageCurrent,$sub_pages,"test.php?p=",2);   ?> 
ログイン後にコピー


ディスカッションに返信 (解決策)

これを使用すると、クリックしてもジャンプしません....

ページがジャンプするはずです。 SQL で $offset、$pagesize の制限も設定する必要があります

出てきました、URL デバッグを見てください

出てきました、URL デバッグを見てください
これは URL ですが、ジャンプしません。

ページへのジャンプがあるはずで、SQL で制限 $offset,$pagesize を設定する必要があります
もっと詳しく教えてください。あなたが言及した設定制限 $offset,$pagesize が見つかりません

あなたのクラスはページング バーを生成するためにのみ使用されます
データベース クエリを自分で制御する必要もあります

機能しない可能性があります

あなたのクラスはページング バーを生成するためにのみ使用されます
データベース クエリも自分で制御する必要があります。モデレータは、それは非常に明確です

$p=$_GET[p]?$_GET[p]:1;$offset=($p-1)*$pagesize;$query=mysql_query("select * from sometable limit $offset,$pagesize);while($rs=mysql_fetch_array($query)){  //code }
ログイン後にコピー
ログイン後にコピー


あなたのこのクラスは、ページングバーを生成するためにのみ使用されます
データベースクエリを自分で制御する必要もあります

$p=$_GET[p]?$_GET[p]:1;$offset=($p-1)*$pagesize;$query=mysql_query("select * from sometable limit $offset,$pagesize);while($rs=mysql_fetch_array($query)){  //code }
ログイン後にコピー
ログイン後にコピー

あなたが言ったことによると。と言いました、今私はこんな感じです 完了、
<?php 	include("../conn/conn.php");	require_once("../class/SubPages.php");	$p=$_GET[p]?$_GET[p]:1;	$offset=($p-1)*$pagesize;	$page_size=15;														//每页显示的条数	$nums = 1024;														//一共有多少页	$sub_pages=10;														//显示多少个分页	$pageCurrent=$_GET["p"];											//当前得到的是第几页	$query = "select * from tbl_apply_register limit $offset,$page_size";	$info = mysql_query($query);	?>
ログイン後にコピー

以下はデータを取得するためのループです
<?php while ($row = mysql_fetch_array($info)){ ?>    <tbody>    	<tr>        <td><input name="flags[]" type="checkbox" value="<?php echo $row[ID];?>" /></td>        <td><?php echo $row[name];?></td>        <td><?php echo $row[position];?></td>        <td><?php echo $row[department];?></td>        <td><?php echo $row[configinfo];?></td>        <td><?php echo $row[number];?></td>        <td><?php echo $row[type];?></td>        <td><?php echo $row[date];?></td>        <td><?php echo $row[note];?></td>        <td><a href="upadte_out.php?ID=<?php echo $row[ID];?>"><img src="../images/edit.gif" /></a>  <a href="del_out_ok.php?ID=<?php echo $row[ID];?>" onclick="javascript:del_sure( )"><img src="../images/del.gif" /></a></td>        </tr>    </tbody>     <?php }?> 	
ログイン後にコピー


これはページングを呼び出すためのものです
<?php $subPages=new SubPages($page_size,$nums,$pageCurrent,$sub_pages,"show_user.php?p=",2);?>
ログイン後にコピー

これで、各ページに表示されるデータの数を制御できますが、クリックした後ページング、ページが見つかりません...
いくつかのヒントを教えてください...

あなたのこのクラスは、ページング バーを生成するためにのみ使用されます
データベース クエリも自分で制御する必要があります
データベースを制御しましたあなたが言った方法によると、ページングをクリックした後に検索ボックスが表示されます。Webページにアクセスできません...

これらのコードはshow_user.phpにありますか?

これらのコードは show_user.php にありますか?
そうですね

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート