PHP universal paging class code_PHP tutorial
php general paging class code This is a PHP paging code that uses methods. We summarized the special features of various paging codes and wrote a PHP general paging class that is simple to use and easy to understand.
php tutorial general paging class code
This is a PHP paging code that uses methods. We summarized the special features of various paging codes and wrote a PHP general paging class that is simple to use and easy to understand.
*/
class dividepage{//Page divider class
private $total;//The total number of records to be displayed
private $url;//requested url address
private $displaypg;//The number of records displayed on each page, the default is 10 records displayed on each page
private $page;//Current page number
private $lastpg;//The total number of pages, that is, the page number of the last page
private $prepg; //Previous page
private $nextpg;//next page
private $firstcount;//The serial number of the number of records starts from 0
private $startd;//The record number where the number of records starts.
private $stopd;//The record number at the end of the number of records.//Constructor
public function __construct($url, $total, $displaypg){
$this->url = $url;//Requested url
$this->total = $total;//Total number of records
//if($displaypg == '')
$this->displaypg = $displaypg;//Number of records displayed on each page
$this->initdividepage();//Initialize paging class
//echo ','.$this->displaypg;
}//Initialize paging class
private function initdividepage(){
//Analyze url
$parse_url = parse_url($this->url);//Interpret url as an array with fixed key-value pairs
$url_query = $parse_url['query'];//Get the query string in the url
if($url_query){//If there is a query string, delete the query field of the current page in the query string, such as: &page=$page or page=$page
ereg('(^|&)page=([0-9]*)', $url_query, $k);
$this->page = $k[2];//Get the value of the current page
$url_query = ereg_replace("(^|&)page=$this->page", '', $url_query);//Delete the query field of the current page in the query string such as: &page=$page or page=$ page
$this->url = str_replace($parse_url['query'], $url_query, $this->url);//Keep other query strings,
$this->page = $this->page ? $this->page : 1;//wIf there is no value for the current page in the query string, set the current page to 1
if($url_query){//If there are other query strings, add the page turning query string in the form of &page=$page
$this->url .= '&page';
}else{//If there is no other query string, add the page turning query string in the form of page=$page
$this->url .= 'page';
}
}else{//If there is no query string, add a page turning query string in the form of ?page=$page after the url
$this->page = 1;
$this->url .= '?page';
}
$this->lastpg = ceil($this->total / $this->displaypg);//Calculate the total number of pages, that is, the page number of the last page
$this->page = min($this->lastpg, $this->page);//If the current page is greater than the total number of pages, the current page is the page number of the last page
$this->prepg = $this->page - 1;//The previous page is the current page minus one www.bKjia.c0m
$this->nextpg = $this->page + 1;//(($this->page == $this->lastpg) ? $this->lastpg : ($this->page + 1));//The next page is the current page plus one. If the current page is the last page, the next page is 0
$this->firstcount = ($this->page - 1) * $this->displaypg;//Calculate the record number of the current page and the number of records, starting from 0.
$this->startd = $this->total ? ($this->firstcount + 1) : 0;//The record start number starts from 1
$this->stopd = min($this->firstcount + $this->displaypg, $this->total);//Record end number
//echo $this->displaypg;
//echo $this->nextpg.'+=+='.$this->lastpg;
}public function getpageinfo(){//Get the basic information of the current page, such as: display records 1-10, a total of 23 records.
return 'Display page '.$this->startd.'-'.$this->stopd.' records, a total of '.$this->total.' records. ';
}public function getcommonpagenav(){//Get common paging navigation, such as: Home Page Previous Page Next Page Last Page
$commonnav = '';
if($this->lastpg == 1){//If there is only one page, return to the page-turning navigation, exit, and do not display the next page, previous page, etc. . .
Return $commonnav;
break;
}
$commonnav = 'Homepage';//Set homepage navigation, page=1
if($this->prepg){
$commonnav .= 'Previous page';
}else{
$commonnav .= 'Previous page';
}
if($this->nextpg <= $this->lastpg){
$commonnav .= 'Next page';
}else{
$commonnav .= 'Next page';
}
$commonnav .= 'Last page';/ /Show last page link
return $commonnav;
}//Get the jump page navigation, such as: page n
public function getjumppagenav(){
////Get all pagination navigation
public function getallpagenav(){
$temp = $this->getpageinfo().$this->getcommonpagenav().$this->getjumppagenav();
return $temp;
}//Get the records to be displayed on the current page, within the limited range in the database tutorial, such as 0-9
public function getlimitstr(){
//echo $this->page;
//echo $this->firstcount;
//echo $this->dispalypg;
$temp = $this->firstcount.','.$this->displaypg;
//echo $temp;
return $temp;
}}
/*
Usage example:
*$result=mysql tutorial_query("select * from tb_pagetest");//Query the data to be displayed from the database
*$total=mysql_num_rows($result);//The total number of queried data
*$pagesize = 5;//Number of records displayed on each page
*$url = $_server['request_uri'];//Requested uri
*
*$dividepageclass = new dividepage($url, $total, $pagesize); //Create a paging class, (the class can be automatically initialized)
*$limitstr = $dividepageclass->getlimitstr();//Get the starting sequence number of the records to be displayed on the current page and the number of records displayed on each page, such as: 0, 5 (display 5 records starting from 0)
*echo $dividepageclass->getallpagenav();//Display all paging navigation bars,
*For example: Display records 11-13, 13 records in total. Home Page Previous Page Next Page Last Page To *Page 1, 3 pages in total
*$sql = 'select * from tb_pagetest limit '.$limitstr;
*$result=mysql_query($sql);//Get the record set to be displayed on the current page from the database, and then display it ok
*For example:
*while($row=mysql_fetch_array($result))
*echo "
".$row[title]." | ".$row[author];

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

In this chapter, we will understand the Environment Variables, General Configuration, Database Configuration and Email Configuration in CakePHP.

PHP 8.4 brings several new features, security improvements, and performance improvements with healthy amounts of feature deprecations and removals. This guide explains how to install PHP 8.4 or upgrade to PHP 8.4 on Ubuntu, Debian, or their derivati

To work with date and time in cakephp4, we are going to make use of the available FrozenTime class.

To work on file upload we are going to use the form helper. Here, is an example for file upload.

In this chapter, we are going to learn the following topics related to routing ?

CakePHP is an open-source framework for PHP. It is intended to make developing, deploying and maintaining applications much easier. CakePHP is based on a MVC-like architecture that is both powerful and easy to grasp. Models, Views, and Controllers gu

Visual Studio Code, also known as VS Code, is a free source code editor — or integrated development environment (IDE) — available for all major operating systems. With a large collection of extensions for many programming languages, VS Code can be c

Validator can be created by adding the following two lines in the controller.
