文章分頁通常是文章內容過長為了方便閱讀而做的一個小處理了,下面我們來一起看一篇關于使用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 (emptyempty($arr_url)){
- $str = "ipage=";
- }else{ //Vevb.com
- $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的文件編碼,會讓你的編碼工作更加順暢.
新聞熱點
疑難解答