찾다
백엔드 개발PHP 문제PHP 페이징 기능 구현에 대해

PHP 페이징 기능 구현에 대해

Jul 22, 2020 am 09:52 AM
php쪽수 매기기

PHP 페이징 기능을 구현하는 방법: 먼저 "parse_url"을 사용하여 URL 배열을 구문 분석한 다음 목록 페이지를 가져오고 표시할 콘텐츠를 수집한 다음 계산된 제한 시작 위치를 $page에 할당합니다. page 및 $pageSize는 데이터베이스로 이동하여 데이터를 검색하고 표시하기 위해 출력합니다.

PHP 페이징 기능 구현에 대해

PHP 페이징 기능 구현

웹사이트에서는 일반적으로 목록 페이지에 내용이 너무 많으면 페이징 기능을 설정하게 되는데, 오늘은 페이징 원리를 연구하고 이를 통해 이 기능을 구현해 보겠습니다. 작은 경우입니다.

추천: "PHP Tutorial"

페이지 원리

페이지 표시, mysql 데이터베이스에서 가져온 데이터는 sql 문의 제한, 시작 데이터를 사용하여 일반 섹션에 표시됩니다. 바인딩하고 페이지 수에 따라 데이터베이스에서 데이터를 가져옵니다

예: 데이터베이스 테이블 이름이 list라고 가정하고 페이지당 10개의 정보를 가져옵니다

    第1页    select * from list limit 0,10;
    第2页   select * from list limit 10,10;
    第3页   select * from list limit 20,10;

이러한 관점에서 n번째 페이지는 select * from list Limit (n-1)*10 ,10;

이 방법으로 페이지 수를 사용하여 데이터를 가져오는 공식을 얻습니다.

select * from list Limit ($page-1)*$ pagesize,$pagesize; $page는 현재 페이지 번호이고, $pagesize는 페이지당 항목 수를 구합니다

필요한 지식 포인트

1.基本的操作数据库函数
1.1 mysqli_connect();连接数据库,例如$link = mysqli_connect('127.0.0.1','root',12345678,'bbs'); 
1.2 mysqli_query():获取数据 例如$res = mysqli_query($link,"select * from list");第二个参数为sql语句
1.3 mysqli_num_rows():查看获取了多少条数据 例如 $num = mysqli_num_rows($res);
1.4 mysqli_fetch_assoc(),或者mysqli_fetch_row():从获取的数据集中取一条数据,每次只取一条,取完指针就指向下一条. 例如mysqli_fetch_assoc($res),除了fetch_assoc,fetch_row还有fetch_array,他们具体的区别请参考手册
1.5 limit 操作数据库中数据的,limit 开始位置,操作条数 例如从数据库中取数 select * from list limit 10,10;
2.其他相关知识
2.1 $_SERVER['REQUEST_URI']获取当前页面的url 例如 https://i.cnblogs.com/EditPosts.aspx?opt=1的url为/EditPosts.aspx?opt=1
2.2 parse_url():解析url,返回url的各个组成部分,如果不写第二个参数,返回的数组中可能的键有以下几种:
    scheme - 如 http,
    host
    port
    user
    pass
    path
    query - 在问号 ? 之后
    fragment - 在散列符号 # 之后

구현 과정

1. URL 배열

2. 서버에 연결하여 목록 페이지에 표시할 콘텐츠 모음을 가져오고, 표시된 항목의 총 개수를 계산한 다음 콘텐츠의 총 페이지 수를 계산합니다

3. 페이지는 제출 상태입니다. 그렇지 않은 경우 기본값은 첫 번째 페이지 $pageval

4입니다. 계산된 제한 시작 위치를 $page

5 변수에 할당합니다. $page 및 $pageSize를 사용하여 데이터베이스에서 데이터를 가져옵니다

6. 데이터 수집을 반복하면 출력이 페이지에 표시됩니다

구체적인 코드는 다음과 같습니다

$url = $_SERVER['REQUEST_URI'];
$url = parse_url($url);
$url = $url['path'];
$pageSize = 4;
//连接服务器
$link = mysqli_connect('127.0.0.1','root',12345678,'bbs');
$res = mysqli_query($link,'select * from fenye');
$num = mysqli_num_rows($res);
$pageNum = ceil($num/$pageSize);
//判断页面是否是提交状态
if ( isset($_GET['page']) && $_GET['page'] >1) {
    $pageVal = $_GET['page'];
}else {
    $pageVal = 1;
}
//计算起始位置
$page = ($pageVal-1)*$pageSize;
//去数据库取数据
$res = $mysqli_query($link,"select * from fenye limit $page,$pageSize");
//如果$res有值,则循环便利结果展示输出在页面
if ($res) {
    while( $row = mysqli_fetch_assoc($res) ) {
    echo $row[&#39;name&#39;]. &#39;|&#39;.$row[&#39;age&#39;].&#39;<br/>&#39;;
    }
}
//html添加页数部分
<a href="?page=1">1</a>;
<a href="?page=2">2</a>;
<a href="?page=3">3</a>;
<a href="?page=4">4</a>;
<a href="?page=5">5</a>;
总共<?php echo $pageNum; ?>页,当前在<?php echo $pageVal;?>页

위 내용은 PHP 페이징 기능 구현에 대해의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

SublimeText3 영어 버전

SublimeText3 영어 버전

권장 사항: Win 버전, 코드 프롬프트 지원!

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

SecList

SecList

SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

맨티스BT

맨티스BT

Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

VSCode Windows 64비트 다운로드

VSCode Windows 64비트 다운로드

Microsoft에서 출시한 강력한 무료 IDE 편집기