當文章內容比較長,為了更好的滿足用戶體驗度,我們將文章內容分頁顯示處理,而一般分頁處理是在後台發布文章的時候就將提交的內容生成多個分頁後的靜態文件。通過本文結合實例采用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(); ?>