Home Backend Development PHP Tutorial How to implement pagination in PHP

How to implement pagination in PHP

Jun 11, 2023 pm 08:09 PM
Array chunking php pagination Loop output

In web applications, the paging function is very necessary when displaying large amounts of data. As a popular web development language, PHP naturally provides a paging implementation method. This article will introduce how to implement paging in PHP.

1. Obtain data

Before implementing paging, you need to obtain the data to be paging. Normally, we need to get data from the database. Here we assume that we use the MySQL database and encapsulate the database connection and query methods through PDO. The following is an example query method:

function query($sql, $params = []) {
    $dsn = "mysql:host=localhost;dbname=mydatabase;charset=utf8mb4";
    $username = "myusername";
    $password = "mypassword";
    $options = [
        PDO::ATTR_EMULATE_PREPARES => false,
        PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION
    ];
    try {
        $pdo = new PDO($dsn, $username, $password, $options);
        $stmt = $pdo->prepare($sql);
        $stmt->execute($params);
        return $stmt->fetchAll(PDO::FETCH_ASSOC);
    } catch (PDOException $e) {
        die("Database error: " . $e->getMessage());
    }
}
Copy after login

We can query data by calling this method, for example:

$result = query("SELECT * FROM mytable");
Copy after login

2. Calculate the total number of pages

After obtaining the data, next One step is to figure out the total number of pages. We can calculate the total number of pages through the following formula:

totalPages = ceil(totalItems / pageSize)
Copy after login

Among them, totalItems represents the total number of items, and pageSize represents the number of items displayed on each page.

In PHP, you can use the built-in ceil() function to round up. The example is as follows:

$totalItems = count($result);
$pageSize = 10;
$totalPages = ceil($totalItems / $pageSize);
Copy after login

3. Get the current page data

Next, we need Get the data to be displayed on the current page. For convenience, we can define a getPageData() function to obtain the current page data. This function needs to pass in the current page number $page and the number of entries displayed on each page $pageSize. The example is as follows:

function getPageData($data, $page, $pageSize) {
    $start = ($page - 1) * $pageSize;
    $end = $start + $pageSize;
    return array_slice($data, $start, $pageSize);
}
Copy after login

This function will Calculate the starting position and ending position based on the current page number, and obtain the corresponding entries from the $data array through the array_slice() function. The example is as follows:

$data = query("SELECT * FROM mytable");
$pageData = getPageData($data, 2, 10); // 获取第2页,每页显示10条数据
Copy after login

4. Generate paging links

Finally The first step is to generate pagination links so that users can easily turn pages. We can generate paging links through the following steps:

  1. Generate page number links based on the total number of pages;
  2. Highlight the corresponding link based on the current page number;
  3. In Add a "previous page" link in front and a "next page" link in the end.

The following is a sample code:

function getPageLinks($currentPage, $totalPages) {
    $links = [];
    for ($i = 1; $i <= $totalPages; $i++) {
        $isActive = $i == $currentPage;
        $links[] = [
            "page" => $i,
            "isActive" => $isActive,
            "url" => "?page=$i",
        ];
    }
    $prevPage = $currentPage - 1;
    $nextPage = $currentPage + 1;
    if ($prevPage >= 1) {
        array_unshift($links, [
            "page" => $prevPage,
            "isActive" => false,
            "url" => "?page=$prevPage",
        ]);
    }
    if ($nextPage <= $totalPages) {
        array_push($links, [
            "page" => $nextPage,
            "isActive" => false,
            "url" => "?page=$nextPage",
        ]);
    }
    return $links;
}
Copy after login

This function will generate the corresponding link array based on the current page number and the total number of pages, including the page number of each link and whether it is the current page , and the URL of the link. Add the "previous page" link in front of the link array and the "next page" link after it to get a complete paging link array.

Usage examples are as follows:

$totalPages = ceil($totalItems / $pageSize);
$pageLinks = getPageLinks($currentPage, $totalPages);
Copy after login

So far, we have introduced all the steps on how to implement paging in PHP. Through the above method, only some simple mathematical calculations and array operations are needed to easily implement the paging function.

The above is the detailed content of How to implement pagination in PHP. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Best Graphic Settings
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. How to Fix Audio if You Can't Hear Anyone
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: How To Unlock Everything In MyRise
4 weeks ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

cURL in PHP: How to Use the PHP cURL Extension in REST APIs cURL in PHP: How to Use the PHP cURL Extension in REST APIs Mar 14, 2025 am 11:42 AM

The PHP Client URL (cURL) extension is a powerful tool for developers, enabling seamless interaction with remote servers and REST APIs. By leveraging libcurl, a well-respected multi-protocol file transfer library, PHP cURL facilitates efficient execution of various network protocols, including HTTP, HTTPS, and FTP. This extension offers granular control over HTTP requests, supports multiple concurrent operations, and provides built-in security features.

12 Best PHP Chat Scripts on CodeCanyon 12 Best PHP Chat Scripts on CodeCanyon Mar 13, 2025 pm 12:08 PM

Do you want to provide real-time, instant solutions to your customers' most pressing problems? Live chat lets you have real-time conversations with customers and resolve their problems instantly. It allows you to provide faster service to your custom

Explain the concept of late static binding in PHP. Explain the concept of late static binding in PHP. Mar 21, 2025 pm 01:33 PM

Article discusses late static binding (LSB) in PHP, introduced in PHP 5.3, allowing runtime resolution of static method calls for more flexible inheritance.Main issue: LSB vs. traditional polymorphism; LSB's practical applications and potential perfo

Explain JSON Web Tokens (JWT) and their use case in PHP APIs. Explain JSON Web Tokens (JWT) and their use case in PHP APIs. Apr 05, 2025 am 12:04 AM

JWT is an open standard based on JSON, used to securely transmit information between parties, mainly for identity authentication and information exchange. 1. JWT consists of three parts: Header, Payload and Signature. 2. The working principle of JWT includes three steps: generating JWT, verifying JWT and parsing Payload. 3. When using JWT for authentication in PHP, JWT can be generated and verified, and user role and permission information can be included in advanced usage. 4. Common errors include signature verification failure, token expiration, and payload oversized. Debugging skills include using debugging tools and logging. 5. Performance optimization and best practices include using appropriate signature algorithms, setting validity periods reasonably,

Framework Security Features: Protecting against vulnerabilities. Framework Security Features: Protecting against vulnerabilities. Mar 28, 2025 pm 05:11 PM

Article discusses essential security features in frameworks to protect against vulnerabilities, including input validation, authentication, and regular updates.

Customizing/Extending Frameworks: How to add custom functionality. Customizing/Extending Frameworks: How to add custom functionality. Mar 28, 2025 pm 05:12 PM

The article discusses adding custom functionality to frameworks, focusing on understanding architecture, identifying extension points, and best practices for integration and debugging.

How to send a POST request containing JSON data using PHP's cURL library? How to send a POST request containing JSON data using PHP's cURL library? Apr 01, 2025 pm 03:12 PM

Sending JSON data using PHP's cURL library In PHP development, it is often necessary to interact with external APIs. One of the common ways is to use cURL library to send POST�...

See all articles