>백엔드 개발 >PHP 튜토리얼 >새로 고치지 않는 페이징의 PHP+Ajax 구현 방법 및 예에 대한 자세한 설명

새로 고치지 않는 페이징의 PHP+Ajax 구현 방법 및 예에 대한 자세한 설명

墨辰丷
墨辰丷원래의
2018-06-04 10:00:442148검색

이 기사에서는 새로 고침 없는 페이징을 달성하기 위한 PHP+Ajax의 방법을 주로 소개하며, 새로 고침 없는 페이징을 달성하기 위해 Ajax와 결합된 PHP의 특정 단계 및 관련 기술을 완전한 예제 형식으로 자세히 분석합니다. 독자들이 참조할 수 있도록 데모 소스 코드가 포함되어 있습니다. 필요한 친구는

참고를 참조하세요. 여기에 사용된 일부 클래스 라이브러리는 이전 기사에서 소스 코드를 찾을 수 있으므로 기사의 길이를 줄이기 위해 , 링크가 표시됩니다.

이 기사에서는 새로 고침 없는 페이징의 Ajax 구현, 구현 원칙, 코드 표시 및 코드 다운로드에 대해 설명합니다.

여기서 몇 가지 지식을 설명해야 합니다.

1. 페이지를 새로 고칠 필요가 없는 Ajax의 이점: 좋은 고객 경험을 제공하고, 데이터베이스에서 데이터를 가져와서 Ajax를 통해 백그라운드에 표시하고, 빈 상태를 제거합니다.

2 그러면 Ajax 비새로고침 페이지가 동적 페이지(.php)에서 실행되나요? 아니면 정적 페이지(.html/.htm/.shtml)입니까? 대답은: 정적 페이지입니다.

3. 구현 원리: 동적 페이지에서 반환된 데이터는 프런트 엔드 JS 스크립트 프로그램과 Ajax의 조합을 통해 얻어지고 표시됩니다.

자, 아래 코드를 설명하겠습니다.

정적 페이지에서 실행되기 때문에 먼저 index.html의 코드 목록은 다음과 같습니다.

index.html

<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<script type="text/javascript" src="js/ajax.js"></script> <!-- 载入 Ajax 类库 -->
<title>Ajax 实现无刷新页面</title>
<style type="text/css">
  body {
    font-size:12px;
  }
</style>
</head>
<body>
  <p id="fpage">数据加载中...</p>
</body>
</html>

코드 목록에는 Ajax 클래스 라이브러리가 로드되어 있습니다. 이 클래스 라이브러리는 이전 기사 "간단한 Ajax 클래스 라이브러리 분석 및 사용 예"에서 찾을 수 있습니다.

이 정적 페이지에는 "데이터 로드 중..."만 표시되고 데이터는 없습니다. 이때 Ajax를 통해 데이터베이스로부터 데이터를 얻기 위해서는 JS 스크립트가 필요합니다. JS 스크립트는 다음과 같습니다.

<script type="text/javascript">
  /**
  * setPage(url) 根据 url 从 article.php 中获取数据
  * @param int pageNum 页码
  * @return string
  */
  var cache=new Array(); // 缓存变量,当数据被访问过之后放置在缓存中,加快访问速度
  function setPage(pageNum) {
    var fpage = document.getElementById(&#39;fpage&#39;); // 获取 fpage 对象
    // 如果缓存中存在数据,那么直接从缓存中读取;如果不存在数据,那么就从数据库中读取,并把数据存入缓存
    if (typeof(cache[pageNum])==&#39;undefined&#39;) {
      var ajax = Ajax();
      ajax.get(&#39;article.php?page=&#39;+pageNum, function(data){
        fpage.innerHTML = data; // fpage对象的内容是从 article.php 中取来的
        cache[pageNum] = data;
      })
    } else {
      fpage.innerHTML = cache[pageNum];
    }
  }
  setPage(1); // 默认执行
</script>

위 코드를 주의 깊게 읽으면 다음 현상을 발견할 수 있습니다.

1. setPage(pageNum)는 데이터베이스에서 데이터를 추출하는 JS 함수 인터페이스입니다. Ajax는 기사 .php 파일을 통해 데이터를 얻습니다.

3.article.php?page=xx, 여기서 xx는 얻을 페이지 번호 데이터입니다.
setPage(1): 첫 번째 페이지 데이터를 얻습니다. 2): 첫 번째 페이지 데이터 2페이지를 가져옵니다.
setPage(100): 100번째 페이지의 데이터를 가져옵니다.
...

그렇다면 Article.php 파일에서 데이터를 가져오는 방법은 무엇입니까? 아래 코드 목록을 참조하세요.

article.php

<?php
/**
* $Id: article.php
* author Lee.
* Last modify $Date: 2012-01-21 16:53:05 $
*/
require_once &#39;./config.inc.php&#39;;
$m = new Model();
$page = new ajaxPage($m->total(&#39;article&#39;),20); // $m->total(&#39;article&#39;) 获取 article 表的记录数;10为每页显示十条
$result = $m->fetchAll(&#39;article&#39;, &#39;*&#39;, &#39;&#39;, &#39;&#39;, $page->limit); // 取出数据,^_^,很方便吧
echo &#39;<table align="center" border="1" width="1100" style="border-collapse:collapse;font-size:14px;" bordercolor="#666">&#39;;
echo &#39;<caption><h1>华强电子网资讯</h1></caption>&#39;;
echo &#39;<tr height="25"><th>ID</th><th>Title</th><th>Author</th><th>Source</th><th>Date</th></tr>&#39;;
foreach ($result as $v) {
  echo "<tr height=&#39;21&#39;><td align=&#39;center&#39;>{$v[&#39;id&#39;]}</td><td>{$v[&#39;title&#39;]}</td><td align=&#39;center&#39;>{$v[&#39;author&#39;]}</td><td align=&#39;center&#39;>{$v[&#39;source&#39;]}</td><td align=&#39;center&#39;>{$v[&#39;date&#39;]}</td></tr>";
}
echo &#39;<tr><td align="right" colspan="5">&#39;.$page->fpage().&#39;</td></tr>&#39;;
echo &#39;</table>&#39;;
?>

article.php에 연결된 데이터는 이전 글에서 화창전자망에서 캡쳐한 정보 데이터인데, 데이터 용량이 비교적 크기 때문에 기사.sql 파일을 첨부하겠습니다. 모두가 테스트할 수 있도록 코드 패키지를 다운로드하세요.

정적 페이지 index.html에 표시되는 데이터는 Article.php 파일의 에코 코드입니다.

코드 파일의 config.inc.php 파일은 주로 데이터베이스 사용자 이름, 데이터베이스 비밀번호, 호스트..., 데이터베이스 연결 클래스 라이브러리(Db.class.php) 및 데이터베이스 작업 클래스 라이브러리(모델)와 같은 일부 상수를 정의합니다. .class .php), 사용법 지침과 함께 "PHP의 일반적인 PDO 클래스 라이브러리 예 분석" 기사를 참조하세요.


프로그램 렌더링:

아래 그림은 주의해야 할 부분을 표시합니다.

이렇게 Ajax 비 새로 고침 페이징이 완료됩니다. 프로그램에는 설명되지 않은 ajaxPage.class.php도 있는데 사실 이 ajaxPage 클래스 라이브러리의 사용법은 일반 페이징 클래스 라이브러리와 동일합니다.

즉: $page = new ajaxPage(총 레코드 수, 페이지당 표시 수);

요약: 위 내용은 이 기사의 전체 내용이므로 모든 사람의 학습에 도움이 되기를 바랍니다.

관련 권장사항:

PHP는 로그인 인증 코드 기능과 호출 방법을 구현합니다.


php

파일 업로드의 백엔드 처리를 위한 팁
PHP는 기사의 첫 번째 사진을 가져옵니다. 약어로 웹사이트 스케치하는 방법


위 내용은 새로 고치지 않는 페이징의 PHP+Ajax 구현 방법 및 예에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.