ページング表示メッセージ機能を備えたシンプルなゲストブックをPHPで開発
ページ上のすべてのユーザーコメントを表示し、ページングを通じて表示します。
ページングの一般的な考え方は次のとおりです。まず、各ページに表示する必要があるメッセージの数を決定し、メッセージの合計数を各ページに表示されるメッセージの数で割って、合計ページ数を取得します。均等に分割できない場合は、余りが別ページとなり、総ページ数+1となります。

前のセクションで設定したデータベースの LyDB クラスを引き続き使用します。
ここでは1ページに3つのデータを表示するように設定しています
<?php $page_size=3; ?>
各ページに表示する数page_size、メッセージ数ly_count、総ページ数page_countをpublic関数を使って配列arrayに代入します
<?php
class LyDb{
//....省略
public function select_page_info(){
$sql = "select count(*) as pagecount from ly";
$query = mysqli_query($this->link,$sql);
$row = mysqli_fetch_assoc($query);
$ly_count=$row["pagecount"];
$page_count=($ly_count%$this->page_size==0)?($ly_count/$this->page_size):($ly_count/$this->page_size+1);
$page_info=array("ly_count"=> $ly_count,"page_count"=>(int)$page_count,"page_size"=>$this->page_size);
return $page_info;
}
//......省略
}
?> パブリック関数を使用して現在のページを$page_noに設定します
現在のページが1未満と判断された場合、現在のページが取得した総ページ数より大きい場合は、最初のページを表示し続けます。最後のページが表示されます
最初と最後のページを決定します
<?php
lass LyDb{
//....省略
public function select_page_result(&$page_no){
$page_info=$this->select_page_info();
if(!isset($page_no))$page_no=1;
else if($page_no<1)$page_no=1;
else if($page_no>$page_info["page_count"])$page_no=$page_info["page_count"];
$first=($page_no-1)*$this->page_size;
$sql="select * from ly order by id desc limit $first,$this->page_size ";
$query=mysqli_query($this->link,$sql);
$page_result=array("page_data"=>$query,"page_info"=>$page_info,"page_no"=>$page_no);
return $page_result;
}
//......省略
}
?>フロントエンドページにページング機能を追加します
<div class="pagination" > 当前第<?php echo $page_result["page_no"];?>页/ 共<?php echo $page_result["page_info"]["page_count"];?>页/ 每页显示<?php echo $page_result["page_info"]["page_size"]; ?>条/ 共<?php echo $page_result["page_info"]["ly_count"]; ?>条留言 <a href="index.php?pn=<?php echo ($page_result['page_no']-1);?>">上一页</a> <a href="index.php?pn=<?php echo ($page_result['page_no']+1);?>">下一页</a> <a href="index.php?pn=1">首页</a> <a href="index.php?pn=<?php echo ($page_result['page_info']['page_count']);?>">尾页</a> </div>
新しいファイル
<div class="pagination" >
当前第<?php echo $page_result["page_no"];?>页/
共<?php echo $page_result["page_info"]["page_count"];?>页/
每页显示<?php echo $page_result["page_info"]["page_size"]; ?>条/
共<?php echo $page_result["page_info"]["ly_count"]; ?>条留言
<a href="index.php?pn=<?php echo ($page_result['page_no']-1);?>">上一页</a>
<a href="index.php?pn=<?php echo ($page_result['page_no']+1);?>">下一页</a>
<a href="index.php?pn=1">首页</a>
<a href="index.php?pn=<?php echo ($page_result['page_info']['page_count']);?>">尾页</a>
</div>
プレビュー
Clear
- おすすめコース
- コースウェアのダウンロード
現時点ではコースウェアはダウンロードできません。現在スタッフが整理中です。今後もこのコースにもっと注目してください〜
このコースを視聴した生徒はこちらも学んでいます
















