php のページング関数の実装方法: 最初に「parse_url」を使用して URL 配列を解析し、次にリスト ページを取得して表示するコンテンツを収集し、計算された制限開始位置を変数 $ に代入します。最後に、$page と $pageSize を使用してデータベースからデータを取得し、表示用に出力します。
#phpページング機能の実現
Webサイトにおいて、一覧ページのコンテンツが多すぎると、通常、ページングは関数に設定されます。今日はページングの原理を一緒に学習し、小さなケースを通じてこの関数を実装します。 推奨: "PHP チュートリアル "
#ページングの原則ページ表示では、mysql データベースから取得したデータが通常のセクションに表示されます。SQL ステートメントの制限を使用して、開始データをページ数にバインドし、ページ数に応じてデータベースからデータを取得します。
例: データベースのテーブル名が list で、各ページから 10 個の情報が取得されるとします。
第1页 select * from list limit 0,10; 第2页 select * from list limit 10,10; 第3页 select * from list limit 20,10;
ここからビューでは、n 番目のページは select * from list limit (n-1)*10,10 ;
このようにして、ページ数を使用してデータを取得する式を取得します:
select * リスト制限 ($page-1) から*$pagesize,$pagesize; $page は現在のページ数、$pagesize はページごとのアイテム数です。
必要な知識ポイント
1.基本的操作数据库函数 1.1 mysqli_connect();连接数据库,例如$link = mysqli_connect('127.0.0.1','root',12345678,'bbs'); 1.2 mysqli_query():获取数据 例如$res = mysqli_query($link,"select * from list");第二个参数为sql语句 1.3 mysqli_num_rows():查看获取了多少条数据 例如 $num = mysqli_num_rows($res); 1.4 mysqli_fetch_assoc(),或者mysqli_fetch_row():从获取的数据集中取一条数据,每次只取一条,取完指针就指向下一条. 例如mysqli_fetch_assoc($res),除了fetch_assoc,fetch_row还有fetch_array,他们具体的区别请参考手册 1.5 limit 操作数据库中数据的,limit 开始位置,操作条数 例如从数据库中取数 select * from list limit 10,10; 2.其他相关知识 2.1 $_SERVER['REQUEST_URI']获取当前页面的url 例如 https://i.cnblogs.com/EditPosts.aspx?opt=1的url为/EditPosts.aspx?opt=1 2.2 parse_url():解析url,返回url的各个组成部分,如果不写第二个参数,返回的数组中可能的键有以下几种: scheme - 如 http, host port user pass path query - 在问号 ? 之后 fragment - 在散列符号 # 之后
実装プロセス
1. 現在の URL 文字列を取得し、parse_url を使用して解析して URL 配列を取得します
2. サーバーに接続し、表示するコンテンツ コレクションを取得しますリスト ページ、表示されるアイテムの総数を数え、コンテンツの総ページ数を計算します
3. ページが送信済み状態かどうかを確認します (送信済み状態でない場合は、デフォルトは最初のページです) $pageval
4. 計算された制限開始位置を変数 $page
5. $page と $pageSize を使用してデータベースからデータをフェッチします
6. ループします。データが収集され、出力がページに表示されます
具体的なコードは次のとおりです
$url = $_SERVER['REQUEST_URI']; $url = parse_url($url); $url = $url['path']; $pageSize = 4; //连接服务器 $link = mysqli_connect('127.0.0.1','root',12345678,'bbs'); $res = mysqli_query($link,'select * from fenye'); $num = mysqli_num_rows($res); $pageNum = ceil($num/$pageSize); //判断页面是否是提交状态 if ( isset($_GET['page']) && $_GET['page'] >1) { $pageVal = $_GET['page']; }else { $pageVal = 1; } //计算起始位置 $page = ($pageVal-1)*$pageSize; //去数据库取数据 $res = $mysqli_query($link,"select * from fenye limit $page,$pageSize"); //如果$res有值,则循环便利结果展示输出在页面 if ($res) { while( $row = mysqli_fetch_assoc($res) ) { echo $row['name']. '|'.$row['age'].'<br/>'; } } //html添加页数部分 <a href="?page=1">1</a>; <a href="?page=2">2</a>; <a href="?page=3">3</a>; <a href="?page=4">4</a>; <a href="?page=5">5</a>; 总共<?php echo $pageNum; ?>页,当前在<?php echo $pageVal;?>页
以上がPHPのページング機能の実装についての詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。