PHP 페이징 기능을 구현하는 방법: 먼저 "parse_url"을 사용하여 URL 배열을 구문 분석한 다음 목록 페이지를 가져오고 표시할 콘텐츠를 수집한 다음 계산된 제한 시작 위치를 $page에 할당합니다. page 및 $pageSize는 데이터베이스로 이동하여 데이터를 검색하고 표시하기 위해 출력합니다.
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['name']. '|'.$row['age'].'<br/>'; } } //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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

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

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

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

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

VSCode Windows 64비트 다운로드
Microsoft에서 출시한 강력한 무료 IDE 편집기