PHP分頁顯示制作詳細(xì)講解_PHP教程
Jul 21, 2016 pm 04:08 PM
1、前言
分頁顯示是一種非常常見的瀏覽和顯示大量數(shù)據(jù)的方法,屬于web編程中最常處理的事件之一。對(duì)于web編程的老手來說,編寫這種代碼實(shí)在是和呼吸一樣自然,但是對(duì)于初學(xué)者來說,常常對(duì)這個(gè)問題摸不著頭緒,因此特地撰寫此文對(duì)這個(gè)問題進(jìn)行詳細(xì)的講解,力求讓看完這篇文章的朋友在看完以后對(duì)于分頁顯示的原理和實(shí)現(xiàn)方法有所了解。本文適合初學(xué)者閱讀,所有示例代碼均使用php編寫。
2、原理
所謂分頁顯示,也就是將數(shù)據(jù)庫中的結(jié)果集人為的分成一段一段的來顯示,這里需要兩個(gè)初始的參數(shù):
每頁多少條記錄($PageSize)?
當(dāng)前是第幾頁($CurrentPageID)?
現(xiàn)在只要再給我一個(gè)結(jié)果集,我就可以顯示某段特定的結(jié)果出來。
至于其他的參數(shù),比如:上一頁($PreviousPageID)、下一頁($NextPageID)、總頁數(shù)($numPages)等等,都可以根據(jù)前邊這幾個(gè)東西得到。
以mysql數(shù)據(jù)庫為例,如果要從表內(nèi)截取某段內(nèi)容,sql語句可以用:select * from table limit offset, rows??纯聪旅嬉唤Msql語句,嘗試一下發(fā)現(xiàn)其中的規(guī)率。
前10條記錄:select * from table limit 0,10
第11至20條記錄:select * from table limit 10,10
第21至30條記錄:select * from table limit 20,10
……
這一組sql語句其實(shí)就是當(dāng)$PageSize=10的時(shí)候取表內(nèi)每一頁數(shù)據(jù)的sql語句,我們可以總結(jié)出這樣一個(gè)模板:
select * from table limit ($CurrentPageID - 1) * $PageSize, $PageSize
拿這個(gè)模板代入對(duì)應(yīng)的值和上邊那一組sql語句對(duì)照一下看看是不是那么回事。搞定了最重要的如何獲取數(shù)據(jù)的問題以后,剩下的就僅僅是傳遞參數(shù),構(gòu)造合適的sql語句然后使用php從數(shù)據(jù)庫內(nèi)獲取數(shù)據(jù)并顯示了。以下我將用具體代碼加以說明。
3、簡單代碼
請(qǐng)?jiān)敿?xì)閱讀以下代碼,自己調(diào)試運(yùn)行一次,最好把它修改一次,加上自己的功能,比如搜索等等。
// 建立數(shù)據(jù)庫連接
$link = mysql_connect("localhost", "mysql_user", "mysql_password")
????? or die("Could not connect: " . mysql_error());
// 獲取當(dāng)前頁數(shù)
if( isset($_GET['page']) ){
?? $page = intval( $_GET['page'] );
}
else{
?? $page = 1;
}
// 每頁數(shù)量
$PageSize = 10;
// 獲取總數(shù)據(jù)量
$sql = "select count(*) as amount from table";
$result = mysql_query($sql);
$row = mysql_fetch_row($result);
$amount = $row['amount'];
// 記算總共有多少頁
if( $amount ){
?? if( $amount ?? if( $amount % $page_size ){????????????????????????????????? //取總數(shù)據(jù)量除以每頁數(shù)的余數(shù)
?????? $page_count = (int)($amount / $page_size) + 1;?????????? //如果有余數(shù),則頁數(shù)等于總數(shù)據(jù)量除以每頁數(shù)的結(jié)果取整再加一
?? }else{
?????? $page_count = $amount / $page_size;????????????????????? //如果沒有余數(shù),則頁數(shù)等于總數(shù)據(jù)量除以每頁數(shù)的結(jié)果
?? }
}
else{
?? $page_count = 0;
}
// 翻頁鏈接
$page_string = '';
if( $page == 1 ){
?? $page_string .= '第一頁|上一頁|';
}
else{
?? $page_string .= '第一頁|上一頁|';
}
if( ($page == $page_count) || ($page_count == 0) ){
?? $page_string .= '下一頁|尾頁';
}
else{
?? $page_string .= '下一頁|尾頁';
}
// 獲取數(shù)據(jù),以二維數(shù)組格式返回結(jié)果
if( $amount ){
?? $sql = "select * from table order by id desc limit ". ($page-1)*$page_size .", $page_size";
?? $result = mysql_query($sql);
?? while ( $row = mysql_fetch_row($result) ){
?????? $rowset[] = $row;
?? }
}else{
?? $rowset = array();
}
// 沒有包含顯示結(jié)果的代碼,那不在討論范圍,只要用foreach就可以很簡單的用得到的二維數(shù)組來顯示結(jié)果
?>
4、OO風(fēng)格代碼
以下代碼中的數(shù)據(jù)庫連接是使用的pear db類進(jìn)行處理
// FileName: Pager.class.php
// 分頁類,這個(gè)類僅僅用于處理數(shù)據(jù)結(jié)構(gòu),不負(fù)責(zé)處理顯示的工作
Class Pager
{
?? var $PageSize;???????????? //每頁的數(shù)量
?? var $CurrentPageID;??????? //當(dāng)前的頁數(shù)
?? var $NextPageID;?????????? //下一頁
?? var $PreviousPageID;?????? //上一頁
?? var $numPages;???????????? //總頁數(shù)
?? var $numItems;???????????? //總記錄數(shù)
?? var $isFirstPage;????????? //是否第一頁
?? var $isLastPage;?????????? //是否最后一頁
?? var $sql;????????????????? //sql查詢語句
? function Pager($option)
?? {
?????? global $db;
?????? $this->_setOptions($option);
?????? // 總條數(shù)
?????? if ( !isset($this->numItems) )
?????? {
?????????? $res = $db->query($this->sql);
?????????? $this->numItems = $res->numRows();
?????? }
?????? // 總頁數(shù)
?????? if ( $this->numItems > 0 )
?????? {
?????????? if ( $this->numItems PageSize ){ $this->numPages = 1; }
?????????? if ( $this->numItems % $this->PageSize )
?????????? {
?????????????? $this->numPages= (int)($this->numItems / $this->PageSize) + 1;
?????????? }
?????????? else
?????????? {
?????????????? $this->numPages = $this->numItems / $this->PageSize;
?????????? }
?????? }
?????? else
?????? {
?????????? $this->numPages = 0;
?????? }
?????? switch ( $this->CurrentPageID )
?????? {
?????????? case $this->numPages == 1:
?????????????? $this->isFirstPage = true;
?????????????? $this->isLastPage = true;
?????????????? break;
?????????? case 1:
?????????????? $this->isFirstPage = true;
?????????????? $this->isLastPage = false;
?????????????? break;
?????????? case $this->numPages:
?????????????? $this->isFirstPage = false;
?????????????? $this->isLastPage = true;
?????????????? break;
?????????? default:
?????????????? $this->isFirstPage = false;
?????????????? $this->isLastPage = false;
?????? }
?????? if ( $this->numPages > 1 )
?????? {
?????????? if ( !$this->isLastPage ) { $this->NextPageID = $this->CurrentPageID + 1; }
?????????? if ( !$this->isFirstPage ) { $this->PreviousPageID = $this->CurrentPageID - 1; }
?????? }
?????? return true;
?? }
?? /***
??? *
??? * 返回結(jié)果集的數(shù)據(jù)庫連接
??? * 在結(jié)果集比較大的時(shí)候可以直接使用這個(gè)方法獲得數(shù)據(jù)庫連接,然后在類之外遍歷,這樣開銷較小
??? * 如果結(jié)果集不是很大,可以直接使用getPageData的方式獲取二維數(shù)組格式的結(jié)果
??? * getPageData方法也是調(diào)用本方法來獲取結(jié)果的
??? *
??? ***/
?? function getDataLink()
?? {
?????? if ( $this->numItems )
?????? {
?????????? global $db;
?????????? $PageID = $this->CurrentPageID;
?????????? $from = ($PageID - 1)*$this->PageSize;
?????????? $count = $this->PageSize;
?????????? $link = $db->limitQuery($this->sql, $from, $count);?? //使用Pear DB::limitQuery方法保證數(shù)據(jù)庫兼容性
?????????? return $link;
?????? }
?????? else
?????? {
?????????? return false;
?????? }
?? }
?? /***
??? *
??? * 以二維數(shù)組的格式返回結(jié)果集
??? *
??? ***/
?? function getPageData()
?? {
?????? if ( $this->numItems )
?????? {
?????????? if ( $res = $this->getDataLink() )
?????????? {??????
?????????????? if ( $res->numRows() )
?????????????? {
?????????????????? while ( $row = $res->fetchRow() )
?????????????????? {
?????????????????????? $result[] = $row;
?????????????????? }
?????????????? }
?????????????? else
?????????????? {
?????????????????? $result = array();
?????????????? }
?????????????? return $result;
?????????? }
?????????? else
?????????? {
?????????????? return false;
?????????? }
?????? }
?????? else
?????? {
?????????? return false;
?????? }
?? }
?? function _setOptions($option)
?? {
?????? $allow_options = array(
?????????????????? 'PageSize',
?????????????????? 'CurrentPageID',
?????????????????? 'sql',
?????????????????? 'numItems'
?????? );
?????? foreach ( $option as $key => $value )
?????? {
?????????? if ( in_array($key, $allow_options) && ($value != null) )
?????????? {
?????????????? $this->$key = $value;
?????????? }
?????? }
?????? return true;
?? }
}
?>
// FileName: test_pager.php
// 這是一段簡單的示例代碼,前邊省略了使用pear db類建立數(shù)據(jù)庫連接的代碼
require "Pager.class.php";
if ( isset($_GET['page']) )
{
?? $page = (int)$_GET['page'];
}
else
{
?? $page = 1;
}
$sql = "select * from table order by id";
$pager_option = array(
?????? "sql" => $sql,
?????? "PageSize" => 10,
?????? "CurrentPageID" => $page
);
if ( isset($_GET['numItems']) )
{
?? $pager_option['numItems'] = (int)$_GET['numItems'];
}
$pager = @new Pager($pager_option);
$data = $pager->getPageData();
if ( $pager->isFirstPage )
{
?? $turnover = "首頁|上一頁|";
}
else
{
?? $turnover = "首頁|上一頁|";
}
if ( $pager->isLastPage )
{
?? $turnover .= "下一頁|尾頁";
}
else
{
?? $turnover .= "下一頁|尾頁";
}
?>
?
需要說明的地方有兩個(gè):
這個(gè)類僅僅處理數(shù)據(jù),并不負(fù)責(zé)處理顯示,因?yàn)槲矣X得將數(shù)據(jù)的處理和結(jié)果的顯示都放到一個(gè)類里邊實(shí)在是有些勉強(qiáng)。顯示的時(shí)候情況和要求多變,不如自己根據(jù)類給出的結(jié)果處理,更好的方法是根據(jù)這個(gè)Pager類繼承一個(gè)自己的子類來顯示不同的分頁,比如顯示用戶分頁列表可以:
Class MemberPager extends Pager
{
?? function showMemberList()
?? {
?????? global $db;
?????? $data = $this->getPageData();
// 顯示結(jié)果的代碼
?????? // ......
?? }
}
/// 調(diào)用
if ( isset($_GET['page']) )
{
?? $page = (int)$_GET['page'];
}
else
{
?? $page = 1;
}
$sql = "select * from members order by id";
$pager_option = array(
?????? "sql" => $sql,
?????? "PageSize" => 10,
?????? "CurrentPageID" => $page
);
if ( isset($_GET['numItems']) )
{
?? $pager_option['numItems'] = (int)$_GET['numItems'];
}
$pager = @new MemberPager($pager_option);
$pager->showMemberList();
?>
?
第二個(gè)需要說明的地方就是不同數(shù)據(jù)庫的兼容性,在不同的數(shù)據(jù)庫里截獲一段結(jié)果的寫法是不一樣的。
mysql: select * from table limit offset, rows
pgsql: select * from table limit m offset n
......
所以要在類里邊獲取結(jié)果的時(shí)候需要使用pear db類的limitQuery方法。
ok,寫完收功,希望花時(shí)間看完這些文字的你不覺得是浪費(fèi)了時(shí)間。
?

Hei?e KI -Werkzeuge

Undress AI Tool
Ausziehbilder kostenlos

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem v?llig kostenlosen KI-Gesichtstausch-Tool aus!

Hei?er Artikel

Hei?e Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Benutzerspracheingabe wird erfasst und über die Mediarecorder-API des Front-End-JavaScript an das PHP-Backend gesendet. 2. PHP speichert das Audio als tempor?re Datei und ruft STTAPI (z. B. Google oder Baidu Voiceerkennung) auf, um sie in Text umzuwandeln. 3. PHP sendet den Text an einen KI -Dienst (wie OpenAigpt), um intelligente Antwort zu erhalten. 4. PHP ruft dann TTSAPI (wie Baidu oder Google Voice -Synthese) auf, um die Antwort in eine Sprachdatei umzuwandeln. 5. PHP streams die Sprachdatei zurück zum Spielen, um die Interaktion abzuschlie?en. Der gesamte Prozess wird von PHP dominiert, um eine nahtlose Verbindung zwischen allen Links zu gew?hrleisten.

Die Kernmethode zum Aufbau sozialer Freigabefunktionen in PHP besteht darin, dynamisch Freigabelinks zu generieren, die den Anforderungen jeder Plattform entsprechen. 1. Erhalten Sie zuerst die aktuelle Seite oder die angegebenen URL- und Artikelinformationen. 2. Verwenden Sie Urlencode, um die Parameter zu codieren. 3.. Splei? und generieren Teilenverbindungen gem?? den Protokollen jeder Plattform; 4. Zeigen Sie Links im vorderen Ende an, damit Benutzer klicken und freigeben k?nnen. 5. generieren Sie Dynamik OG -Tags auf der Seite, um die Anzeige der Freigabe inhaltlich zu optimieren. 6. Achten Sie darauf, dass Sie den Benutzereingaben entkommen, um XSS -Angriffe zu verhindern. Diese Methode erfordert keine komplexe Authentifizierung, weist nur geringe Wartungskosten auf und eignet sich für die meisten Anforderungen an den Inhaltsaustausch.

Um die Textfehlerkorrektur und die Syntaxoptimierung mit AI zu realisieren, müssen Sie die folgenden Schritte ausführen: 1. W?hlen Sie ein geeignetes AI -Modell oder ein geeignetes AI -Modell oder ein geeignetes AI -Modell wie Baidu, Tencent API oder Open Source NLP -Bibliothek aus; 2. Rufen Sie die API über die Curl oder das Guzzle von PHP auf und verarbeiten Sie die Rückgabeergebnisse. 3.. Informationen zur Fehlerkorrektur in der Anwendung anzeigen und erm?glichen den Benutzern, zu w?hlen, ob sie angenommen werden sollen. 4. Verwenden Sie PHP-L und PHP_CODESNIFFER für die Syntaxerkennung und -codeoptimierung. 5. sammeln Sie kontinuierlich Feedback und aktualisieren Sie das Modell oder die Regeln, um den Effekt zu verbessern. Konzentrieren Sie sich bei der Auswahl von AIAPI auf die Bewertung von Genauigkeit, Reaktionsgeschwindigkeit, Preis und Unterstützung für PHP. Die Codeoptimierung sollte den PSR -Spezifikationen folgen, Cache vernünftigerweise verwenden, zirkul?re Abfragen vermeiden, den Code regelm??ig überprüfen und x verwenden

1. Maximierung des kommerziellen Wertes des Kommentarsystems erfordert die Kombination der pr?zisen Lieferung native Werbung, benutzerbezahlte Wertsch?pfungsdienste (z. B. Bilder hochladen, Aufladungskommentare), den Incentive-Mechanismus basierend auf der Qualit?t der Kommentare und der Anonymen Daten Insight-Monetarisierung von Compliance; 2. Die Prüfungsstrategie sollte eine Kombination aus dynamischer Keyword-Filterung und Benutzerkennungsmechanismen vorab der Auditing einsetzen, die durch die Qualit?t der Kommentarqualit?t erg?nzt werden, um die hierarchische Inhaltsbelastung zu erreichen. 3. Die Anti-Pushing erfordert die Konstruktion einer mehrschichtigen Verteidigung: Recaptchav3 sensorlose überprüfung, Honeypot-Honeypot-Feldkennungroboter, IP und Zeitstempelfrequenzgrenze verhindert die Bew?sserung, und die Erkennung von Inhalten markiert verd?chtige Kommentare und st?ndig mit Angriffen.

PHP führt nicht direkt die KI-Image-Verarbeitung durch, sondern integriert sich über APIs, da es in der Webentwicklung und nicht in Bezug auf Computerintensive Aufgaben gut ist. Die API -Integration kann die professionelle Arbeitsteilung erreichen, die Kosten senken und die Effizienz verbessern. 2. Integration von Schlüsseltechnologien umfasst die Verwendung von Guzzle oder Curl zum Senden von HTTP-Anforderungen, JSON-Datencodierung und -decodierung, API-Schlüsselsicherheitsauthentifizierung, asynchroner Warteschlangenverarbeitungsaufgaben, robuster Fehlerbehebung und Wiederholungsmechanismus, Bildspeicherung und Anzeige. 3. Die gemeinsamen Herausforderungen sind API -Kosten au?er Kontrolle, unkontrollierbare Erzeugungsergebnisse, schlechte Benutzererfahrung, Sicherheitsrisiken und schwieriges Datenmanagement. In den Antwortstrategien werden Benutzerquoten und -darstellungen festgelegt, die Auswahl von ProPT-Anleitungen und mehrfizierende Auswahl, asynchrone Benachrichtigungen und Fortschrittsaufforderungen, wichtige Speicher- und Inhaltsprüfungen sowie Cloud-Speicher vorhanden.

PHP sorgt für die Inventarabzugsatomizit?t durch Datenbanktransaktionen und Forupdate -Reihenschl?sser, um eine hohe gleichzeitige überverl?ssigkeit zu verhindern. 2. Multi-Plattform-Inventarkonsistenz h?ngt von zentraler Verwaltung und ereignisgesteuerter Synchronisation ab, die API/Webhook-Benachrichtigungen und Nachrichtenwarteschlangen kombiniert, um eine zuverl?ssige Datenübertragung sicherzustellen. 3. Der Alarmmechanismus sollte in verschiedenen Szenarien niedrige Lagerbest?nde, Null/Negativ -Inventar, unerwünschte Verkaufszyklen, Nachschubzyklen und abnormale Schwankungsstrategien festlegen und die Auswahl von Dingtalk, SMS oder E -Mail -Verantwortlichen gem?? der Dringlichkeit ausw?hlen, und die Alarminformationen müssen vollst?ndig und frei sein, um die Anpassung und die Vergewaltigungsreaktion zu erreichen.

PhpisstillrelevantinMoDernEnterpriseEnvironments.1.ModerPhp (7.xand8.x) Angebote, strenge, jitkompilation und moderne Syntax, machte ma?geschneiderte Foreiglableforlarge-ScaleApplikationen

W?hlen Sie den entsprechenden AI -Spracherkennungsdienst und integrieren Sie PHPSDK. 2. Verwenden Sie PHP, um FFMPEG aufzurufen, um Aufzeichnungen in API-geforderte Formate (z. B. WAV) umzuwandeln. 3. Laden Sie Dateien in Cloud -Speicher hoch und rufen Sie API Asynchrone Recognition auf. 4. Analysieren Sie JSON -Ergebnisse und organisieren Sie Text mithilfe der NLP -Technologie. 5. Word- oder Markdown -Dokumente generieren, um die Automatisierung der Besprechungsunterlagen abzuschlie?en. Der gesamte Prozess muss sicherstellen, dass die Datenverschlüsselung, die Zugriffskontrolle und die Einhaltung der Datenschutz und Sicherheit gew?hrleistet sind.
