ページング効果は Web ページでは一般的ですが、どうすればページングを実現できますか? 今日は、ページング効果を実現する 2 つの方法を実行しました。
まず、データベースにテーブルを作成し、データを挿入する必要があります。これらはすべて必要な前提条件です。図に示すように、特に言うことはありません (ライブラリ名は jereh、テーブル名はn_content) :
ステップ分析:
ページングが必要な場合は、「select * from tableName limit num1,num2」を使用する必要があります。これは制限するステートメントです。 2 つのパラメータで、num1 は検索を開始する番号、num2 は検索する情報の番号です。たとえば、2、3、4 の 3 つのデータを検索したいとします。以下の図に示されています:
わかりました、ステップから始めましょう:
1. クエリを制限する機能を実装する関数を作成します
まずは考えてみましょう この関数を実装するには、まず現在のページ数と1ページに表示する情報の数を仮引数で渡すことができます。次に、
クエリ ステートメント「select * from tableName limit num1,num2」で、pageNum をページ数に設定し、pageSize を 1 ページに複数のデータを表示するように設定します。 #num1 は (pageNum -1) *pageSize、num2 は pageSize です。この関係を理解すると、扱いやすくなります。コードは次のとおりです。
//分页的函数 function news($pageNum = 1, $pageSize = 3) { $array = array(); $coon = mysqli_connect("localhost", "root"); mysqli_select_db($coon, "jereh"); mysqli_set_charset($coon, "utf8"); // limit为约束显示多少条信息,后面有两个参数,第一个为从第几个开始,第二个为长度 $rs = "select * from n_content limit " . (($pageNum - 1) * $pageSize) . "," . $pageSize; $r = mysqli_query($coon, $rs); while ($obj = mysqli_fetch_object($r)) { $array[] = $obj; } mysqli_close($coon,"jereh"); return $array; }
上記のコードでは、注目に値します。 limit の後にスペースを追加する必要があります。追加しないとエラーが発生します。
関連する推奨事項: 「
php 入門チュートリアル 2. 合計ページ数を表示する 2 番目の関数を作成します#これには新しい知識ポイントはありません。これらはすべて以前に書かれた知識ポイントです。コードを見てみましょう。
//显示总页数的函数 function allNews() { $coon = mysqli_connect("localhost", "root"); mysqli_select_db($coon, "jereh"); mysqli_set_charset($coon, "utf8"); $rs = "select count(*) num from n_content"; //可以显示出总页数 $r = mysqli_query($coon, $rs); $obj = mysqli_fetch_object($r); mysqli_close($coon,"jereh"); return $obj->num; }
3. 前処理としてこれら 2 つの関数を呼び出します
次のページとその次のページの結果を取得したいので、get 関数を使用する必要があります。このページはデータを送信するため、ページを更新すると get は確実にデータを取得できないため、三眼算術を使用する必要があります。
<?php @$allNum = allNews(); @$pageSize = 3; //约定每页显示的信息条数 @$pageNum = empty($_GET["pageNum"])?1:$_GET["pageNum"]; @$endPage = ceil($allNum/$pageSize); //总页数 @$array = news($pageNum,$pageSize); ?>
4. ページに表示する
ページに表示したい場合は、foreach ループを使用する必要があります。コードは簡単です。以下を参照してください。
<table border="1" style="text-align: center" cellpadding="0"> <tr> <td>编号</td> <td>新闻标题</td> <td>来源</td> <td>点击率</td> <td>发布日期</td> </tr> <?php foreach($array as $key=>$values){ echo "<tr>"; echo "<td>{$values->id}</td>"; echo "<td>{$values->title}</td>"; echo "<td>{$values->src}</td>"; echo "<td>{$values->indexs}</td>"; echo "<td>{$values->times}</td>"; echo "</tr>"; } ?> </table>
5. 前のページと次のページの効果を実現するには
ページジャンプの効果を実現するには、a タグの href 属性を使用する必要がありますこの pageNum は自分で定義したもので、get で渡されるため、前のステップで $_GET を使用してパラメータを受け入れているため、パラメータを渡すだけで済みます。取得;
首页: "pageNum=1";前のページ: "pageNum=5988925648297af0be804ad15f2a86e8" 次のページ:"pageNum=6d5ceb5f7a391f584514a6f07966f4fb"最後のページ:"pageNum=次の点に特別な注意を払う必要があります: "pageNum=" の後にスペースを指定することはできません。コードは次のとおりです:<a href="?pageNum=1">首页</a> <a href="?pageNum=<?php echo $pageNum==1?1:($pageNum-1)?>">上一页</a> <a href="?pageNum=<?php echo $pageNum==$endPage?$endPage:($pageNum+1)?>">下一页</a> <a href="?pageNum=<?php echo $endPage?>">尾页</a>コードは次のとおりです:
効果は次のとおりです:分页 <table border="1" style="text-align: center" cellpadding="0"> <tr> <td>编号</td> <td>新闻标题</td> <td>来源</td> <td>点击率</td> <td>发布日期</td> </tr> <?php foreach($array as $key=>$values){ echo "<tr>"; echo "<td>{$values->id}</td>"; echo "<td>{$values->title}</td>"; echo "<td>{$values->src}</td>"; echo "<td>{$values->indexs}</td>"; echo "<td>{$values->times}</td>"; echo "</tr>"; } ?> </table>
##
以上がPHPでページング機能を実装する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。