用PHP實(shí)現(xiàn)網(wǎng)頁(yè)開發(fā)中的翻頁(yè)跳轉(zhuǎn)_PHP教程
推薦:PHP網(wǎng)站開發(fā)中關(guān)于包含路徑問題的解決方案引言: 關(guān)于PERL與PHP中的包含路徑一直是一個(gè)比較難解的問題,主要是與操作系統(tǒng)和WEB服務(wù)器有關(guān),不可能非常智能化的解決這個(gè)路徑問題。相對(duì)于PERL,PHP的路徑好得多,解決起來也容易得多,因
我們都知道用 php mysql 在 web 頁(yè)實(shí)現(xiàn)數(shù)據(jù)庫(kù)資料全部顯示是非常簡(jiǎn)單而有趣的,數(shù)據(jù)庫(kù)資料很少的情況下頁(yè)面顯示還是讓人滿意的,但是當(dāng)數(shù)據(jù)庫(kù)資料非常多的情況下,頁(yè)面的顯示情況將會(huì)變的非常糟,下面就來介紹一下如何實(shí)現(xiàn)當(dāng)前頁(yè)面數(shù)據(jù)資料顯示數(shù)量及如何實(shí)現(xiàn)動(dòng)態(tài)的翻轉(zhuǎn)功能。
這里將介紹兩種翻頁(yè)顯示功能的實(shí)現(xiàn):
先介紹一下在翻頁(yè)中用到的數(shù)據(jù)庫(kù)語法:
mysql_query("select * from table order by id desc");
這條數(shù)據(jù)庫(kù)語句再熟悉不過了,是用來搜索記錄并倒序地顯示出來,但并不能在翻頁(yè)功能中起作用,而下面這個(gè)擴(kuò)展了的語法才是實(shí)現(xiàn)翻頁(yè)的核心功能:
mysql_query("select * from table order by id desc limit $start,$limit");
這里的 $start 是數(shù)據(jù)庫(kù)搜索的起始行,$limit 是從起始行開始搜索到 $limit 條記錄結(jié)束,好了,有了這個(gè)核心功能后,我們可以開始翻頁(yè)功能了;
這里介紹的功能是翻頁(yè)功能中最簡(jiǎn)單的一種,只能實(shí)現(xiàn)向前翻頁(yè)和向后翻頁(yè),本站的非常新聞和下載中心的翻頁(yè)功能就是這種。
先介紹翻頁(yè)功能實(shí)現(xiàn)的思路:
先確定當(dāng)前頁(yè)固定顯示的數(shù)據(jù)記錄數(shù)量,假設(shè)為 20 條記錄,設(shè)定 $limit 的值為 20:$limit=20;
顯示數(shù)據(jù)庫(kù)記錄時(shí),必須是從第一條開始顯示,所以這里設(shè)置 $start 的初始值為 0:$start=0;
而翻頁(yè)功能的實(shí)現(xiàn)依賴 $start 的動(dòng)態(tài)變化,當(dāng)向后翻頁(yè)時(shí) $start 規(guī)律地加上 $limit:$start $limit;而向前翻頁(yè)時(shí) $start 則規(guī)律地減去 $limit:$start-$limit;
有了以上的思路后,可以開始設(shè)計(jì)程序了 page.php:
| 以下為引用的內(nèi)容: <? //設(shè)置當(dāng)前頁(yè)顯示的數(shù)量(這個(gè)數(shù)量可任意設(shè)置) $limit=20; //初始化數(shù)據(jù)庫(kù)搜索起始記錄 if (!empty($start)) $start=0; mysql_connect("localhost","",""); mysql_select_db(database); //設(shè)置數(shù)據(jù)庫(kù)記錄總數(shù) $result=mysql_query("select * from table"); $num_max=mysql_numrows($result); $result=mysql_query("select * from table order by id desc limit $start,$limit); $num=mysql_numrows($result); echo "<table><tr><td>翻頁(yè)功能</td></tr>"; if (!empty($num)) { for ($i=0;$i<$num;$i ) { $val=mysql_result($result,$i,"val"); $val1=mysql_result($result,$i,"val1"); echo "<tr><td>$val</td><td>$val1</td></tr>"; } } echo "<tr><td>"; //設(shè)置向前翻頁(yè)的跳轉(zhuǎn) $prve=$start-$limit; if ($prve>=0) { echo "<a href=page.php?start=$prve>prve</a>"; } //設(shè)置向后翻頁(yè)的跳轉(zhuǎn) $next=$start $limit; if ($next<$num_max) { echo "<a href=page.php?start=$next>next</a>"; } echo "</td></tr></table>"; ?> |
一個(gè)前翻,后翻功能的程序完成了。但這個(gè)功能對(duì)處理更多資料顯示時(shí),將會(huì)顯得很累贅。下面將會(huì)繼續(xù)介紹功能更強(qiáng)大,更加復(fù)雜的翻頁(yè)功能--循環(huán)翻頁(yè)(我一直都這么叫,因?yàn)檎也坏礁线m的叫法)。
前面介紹了簡(jiǎn)單的翻頁(yè)功能實(shí)現(xiàn),下面介紹的翻頁(yè)功能更加強(qiáng)大,更加復(fù)雜,本站的非常論壇和非常文章就是使用這個(gè)循環(huán)翻頁(yè)功能的。循環(huán)翻頁(yè)是前翻后翻加上數(shù)字共同實(shí)現(xiàn)的,具體的表現(xiàn)形式為:
頁(yè): prve <<1 2 3 4 ....... 20 >> next
里面的數(shù)字表示各當(dāng)前的頁(yè)面,前翻 prve 和后翻 next 已不僅僅是當(dāng)前頁(yè)的前后翻轉(zhuǎn),而是更加復(fù)雜的數(shù)字控制前后翻轉(zhuǎn)。
同以往一樣,在進(jìn)行程序設(shè)計(jì)之前,先理清一下思路,我建議讀者在看完如何實(shí)現(xiàn)循環(huán)翻頁(yè)的功能后,能自己動(dòng)手實(shí)踐一次,因?yàn)檫@里研究的一些方法和思路可能比較抽象。
首先我們大膽假設(shè)數(shù)據(jù)庫(kù)里存有超過 1000 條的記錄,我們希望當(dāng)前顯示 25 條記錄,而數(shù)字翻轉(zhuǎn)控制為 20,因此就有如下的顯示結(jié)果:
頁(yè): 0 1 2 3 ......... 19 >> next
后翻后的顯示結(jié)果:
頁(yè): prve <<20 27 28 ....... 49 >> next
好,我們來看看其中的規(guī)律,一個(gè)固定的顯示數(shù)字 25,一個(gè)固定的數(shù)字控制倍翻 20。我們可以利用這兩個(gè)數(shù)字來實(shí)現(xiàn)循環(huán)翻頁(yè)功能;
首先設(shè)置固定顯示的變量:
$limit=20;
數(shù)據(jù)庫(kù)初始變量的設(shè)置:
$start=0;
數(shù)據(jù)庫(kù)記錄總數(shù)為:$num;
頁(yè)數(shù)變量:$page;
一個(gè)頁(yè)數(shù)循環(huán)顯示的程序如下:
| 以下為引用的內(nèi)容: <? ... $result=mysql_query("select * from table"); $num=mysql_numrows($result); for ($page=0;$page<($num/$limit);$page ) { echo $page; if ($page>0 && ($page )==0) { break; //退出循環(huán) } } ?> |
這段代碼除了顯示數(shù)字外,其它功能一概沒有實(shí)現(xiàn),因?yàn)槎嗔藬?shù)字控制翻轉(zhuǎn),所以必須要有幾個(gè)變量來標(biāo)記并識(shí)別這些控制量,這里用了 $s 來標(biāo)記;這個(gè)變量是用來控制數(shù)字循環(huán)翻頁(yè)控制的,現(xiàn)在可以看看實(shí)現(xiàn)循環(huán)翻頁(yè)的完整代碼 page.php:
| 以下為引用的內(nèi)容: <? $limit=25; if (!empty($start)) $start=0; if (!empty($s)) $s=0; mysql_connect("localhost","",""); mysql_select_db(database); //統(tǒng)計(jì)數(shù)據(jù)庫(kù)記錄總數(shù) $result=mysql_query("select * from table"); $num=mysql_numrows($result); $result=mysql_query("select * from table order by id limit $start,$limit"); $numb=mysql_numrows($result); echo "<table>"; if (!empty($numb)) { for($i=0;$i<$numb;$i ) { $val=mysql_result($result,$i,"val"); $val1=mysql_result($result,$i,"val1"); echo "<tr><td>$val</td><td>$val1</td></tr>"; } } echo "</table>"; //數(shù)字循環(huán)翻頁(yè)的控制 echo "<table>"; echo "<tr><td>頁(yè):</td>"; //前翻控制 if ($s>20) { if ($s==21) { $st=$s-21; } else { $st=$s-20; } $pstart=$st*$limit; echo "<td><a href=page.php?"; echo "start=$pstart&s=$st>prve</a></td>"; } echo "<td> >></td>"; //設(shè)置當(dāng)前頁(yè)對(duì)應(yīng)頁(yè)數(shù)無鏈接功能 $star=$start; //注意循環(huán)的初始附值,仔細(xì)想想為什么不是 0 for ($page=$s;$page<($num/$limit);$page ) { $start=$page*$limit; echo "<td>"; if($page!=$star/$limit) { echo "<a href=page.php?"; echo "start=$start&s=$s>"; } echo $page; if($page!=$star/$limit) { echo "</a>"; } echo "</td>"; //控制數(shù)字頁(yè)面限制顯示功能,控制只顯示 20 頁(yè) if ($page>0 && ($page )==0) { if ($s==0) { $s=$s 21; } else { $s=$s 20; } $start=$start $limit; if ((($num/$limit)-1)>$page) { echo "<td> <<</td><td><a href'page.php?"; echo "start=$start&s=$s>next</a></td>"; } //注意跳出循環(huán)的控制 break; } } echo "</tr></table>"; ?> |
以上的程已序可以完成強(qiáng)大的循環(huán)翻頁(yè)功能。
還有一個(gè)翻頁(yè)功能就是提交翻頁(yè),即在提交表單添入數(shù)據(jù)提交,然后程序跳轉(zhuǎn)到該對(duì)應(yīng)頁(yè),這個(gè)功能實(shí)現(xiàn)起來比較簡(jiǎn)單,就留給讀者自己完成,這里不再介紹......
分享:PHP實(shí)例:PHP生成帶有雪花背景的網(wǎng)站驗(yàn)證碼PHP生成帶有雪花背景的網(wǎng)站驗(yàn)證碼: 以下為引用的內(nèi)容: <?session_start();?> <FORM METHOD=POST ACTION=""> &l
- PHPNOW安裝Memcached擴(kuò)展方法詳解
- php記錄頁(yè)面代碼執(zhí)行時(shí)間
- PHP中獎(jiǎng)概率的抽獎(jiǎng)算法程序代碼
- apache設(shè)置靜態(tài)文件緩存方法介紹
- php對(duì)圖像的各種處理函數(shù)代碼小結(jié)
- PHP 關(guān)于訪問控制的和運(yùn)算符優(yōu)先級(jí)介紹
- 關(guān)于PHP語言構(gòu)造器介紹
- php/js獲取客戶端mac地址的實(shí)現(xiàn)代碼
- php5.5新數(shù)組函數(shù)array_column使用
- PHP preg_match的匹配多國(guó)語言的技巧
- php 中序列化和json使用介紹
- php采集文章中的圖片獲取替換到本地
- 相關(guān)鏈接:
復(fù)制本頁(yè)鏈接| 搜索用PHP實(shí)現(xiàn)網(wǎng)頁(yè)開發(fā)中的翻頁(yè)跳轉(zhuǎn)
- 教程說明:
PHP教程-用PHP實(shí)現(xiàn)網(wǎng)頁(yè)開發(fā)中的翻頁(yè)跳轉(zhuǎn)
。