기사 콘텐츠가 비교적 긴 경우 사용자 경험을 더 잘 만족시키기 위해 기사 콘텐츠를 페이지에 표시합니다. 일반적인 페이징 프로세스는 백그라운드에서 기사를 게시할 때 제출된 콘텐츠에서 여러 페이지의 정적 파일을 생성하는 것입니다. . 이 기사와 예제를 통해 우리는 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(); ?>