ホームページ >バックエンド開発 >PHPチュートリアル >PHP を使用して長い記事のページネーションを行う
記事の内容が長い場合、読みやすさとページ表示の便宜を図るため、通常はページ単位で内容を表示します。一般的なページング プロセスでは、記事をバックグラウンドで公開するときに、送信されたコンテンツから複数のページ分割された静的ファイルを生成します。この記事では、例を使用して、PHP を使用して長い記事コンテンツを動的にページ分割する方法を説明します。
デモのダウンロード ソース コードを表示
手動ページネーション: 通常、コンテンツを編集するときに、{pages} などの特別なページネーション タグが追加されます。送信すると、PHP プログラムのページングが改ページに従って処理され、さまざまな静的ページが生成されます。このページング方法はページ分割では正確ですが、手動で改ページを追加する必要があり、作業負荷が高くなります。
自動ページング: PHP プログラムは、設定された改ページに従ってコンテンツをページ分割し、さまざまな静的ページを生成します。この方法は非常に効率的ですが、さまざまな HTML コード タグを処理するための高い要件があります。
フロントエンド JS ページング: Javascript を使用して長い記事コンテンツをセグメントにインターセプトし、リクエストに応じて異なるセグメント化されたコンテンツを表示して、ページング効果を実現します。このメソッドはコンテンツを一度に読み取り、フロントエンド js がページングを処理するため、優れたエクスペリエンスが提供されます。
この記事のサンプル コードでは、PHP を使用して長い記事コンテンツのページネーションを行う方法について説明します。ページネーションは自動または手動で行うことができます。静的 HTML ページの生成については、この記事の範囲外です。静的記事の導入については後で詳しく説明します。
<?php /* * 长文章分页类 */ class cutpage{ private $pagestr; //被切分的内容 private $pagearr; //被切分文字的数组格式 private $sum_word; //总字数(UTF-8格式的中文字符也包括) private $sum_page; //总页数 private $page_word; //一页多少字 private $cut_tag; //自动分页符 private $cut_custom; //手动分页符 private $ipage; //当前切分的页数,第几页 private $url; function __construct($pagestr,$page_word=1000){ $this->page_word = $page_word; $this->cut_tag = array("</table>", "</div>", "</p>", "<br/>", "”。", "。", ".", "!", "……", "?", ","); $this->cut_custom = "{nextpage}"; $tmp_page = intval(trim($_GET["ipage"])); $this->ipage = $tmp_page>1?$tmp_page:1; $this->pagestr = $pagestr; } function cut_str(){ $str_len_word = strlen($this->pagestr); //获取使用strlen得到的字符总数 $i = 0; if ($str_len_word<=$this->page_word){ //如果总字数小于一页显示字数 $page_arr[$i] = $this->pagestr; }else{ if (strpos($this->pagestr, $this->cut_custom)){ $page_arr = explode($this->cut_custom, $this->pagestr); }else{ $str_first = substr($this->pagestr, 0, $this->page_word); //0-page_word个文字 cutStr为func.global中的函数 foreach ($this->cut_tag as $v){ $cut_start = strrpos($str_first, $v); //逆向查找第一个分页符的位置 if ($cut_start){ $page_arr[$i++] = substr($this->pagestr, 0, $cut_start).$v; $cut_start = $cut_start + strlen($v); break; } } if (($cut_start+$this->page_word)>=$str_len_word){ //如果超过总字数 $page_arr[$i++] = substr($this->pagestr, $cut_start, $this->page_word); }else{ while (($cut_start+$this->page_word)<$str_len_word){ foreach ($this->cut_tag as $v){ $str_tmp = substr($this->pagestr, $cut_start, $this->page_word); //取第cut_start个字后的page_word个字符 $cut_tmp = strrpos($str_tmp, $v); //找出从第cut_start个字之后,page_word个字之间,逆向查找第一个分页符的位置 if ($cut_tmp){ $page_arr[$i++] = substr($str_tmp, 0, $cut_tmp).$v; $cut_start = $cut_start + $cut_tmp + strlen($v); break; } } } if (($cut_start+$this->page_word)>$str_len_word){ $page_arr[$i++] = substr($this->pagestr, $cut_start, $this->page_word); } } } } $this->sum_page = count($page_arr); //总页数 $this->pagearr = $page_arr; return $page_arr; } //显示上一条,下一条 function pagenav(){ $this->set_url(); $str = ''; //$str .= $this->ipage.'/'.$this->sum_page; for($i=1;$i<=$this->sum_page;$i++){ if($i==$this->ipage) { $str.= "<a href='#' class='cur'>".$i."</a> "; }else{ $str.= "<a href='".$this->url.$i."'>".$i."</a> "; } } return $str; } function set_url(){ parse_str($_SERVER["QUERY_STRING"], $arr_url); unset($arr_url["ipage"]); if (empty($arr_url)){ $str = "ipage="; }else{ $str = http_build_query($arr_url)."&ipage="; } $this->url = "http://".$_SERVER["HTTP_HOST"].$_SERVER["PHP_SELF"]."?".$str; } } ?>
上記の Cutpage クラスは、コンテンツのページングを非常にうまく処理でき、ページングに対する異なる HTML タグによって引き起こされる問題にも対処できます。コンテンツに改ページ {nextpage} がある場合、コンテンツは最初に改ページに従って自動的にページングされます。
実際のプロジェクトでは、text.txt ファイルの記事コンテンツを読み込むことを想定しています。データベース関連のテーブル。次に、ページング クラスをインスタンス化し、現在のページに従って対応するページング コンテンツを呼び出して出力し、ページング バーを出力します。
<?php$content = file_get_contents('text.txt'); $ipage = $_GET["ipage"]? intval($_GET["ipage"]):1; $CP = new cutpage($content); $page = $CP->cut_str(); echo $page[$ipage-1]; echo $CP->pagenav();?>
統一 UTF-8 ファイル エンコーディングを使用すると、エンコーディング作業がよりスムーズになることに注意してください。