這是php模版smarty做的,看看吧{ if $page1}
創(chuàng)新互聯(lián)建站專注于陳倉企業(yè)網(wǎng)站建設(shè),成都響應(yīng)式網(wǎng)站建設(shè),電子商務(wù)商城網(wǎng)站建設(shè)。陳倉網(wǎng)站建設(shè)公司,為陳倉等地區(qū)提供建站服務(wù)。全流程定制網(wǎng)站制作,專業(yè)設(shè)計,全程項目跟蹤,創(chuàng)新互聯(lián)建站專業(yè)和態(tài)度為您提供的服務(wù)
a href="{$nowpage}?page=1" 首頁/a
a href="{$nowpage}?page={$page-1}" 上一頁/a
{/if}
{ if $page$pages}
a href="{$nowpage}?page={$page+1}" 下一頁 /a
a href="{$nowpage}?page={$pages}" 末頁/a
{/if} BR
共 span {$total}/span 條 | 每頁 {$step} 條 /span | 共 span class="STYLE3"{$pages}頁
PHP代碼如下:
/*
Author:默默
Date :2006-12-03
*/
$page=isset($_GET['page'])?intval($_GET['page']):1; //這句就是獲取page=18中的page的值,假如不存在page,那么頁數(shù)就是1。
$num=10; //每頁顯示10條數(shù)據(jù)
$db=mysql_connect("host","name","pass"); //創(chuàng)建數(shù)據(jù)庫連接
$select=mysql_select_db("db",$db); //選擇要操作的數(shù)據(jù)庫
/*
首先咱們要獲取數(shù)據(jù)庫中到底有多少數(shù)據(jù),才能判斷具體要分多少頁,具體的公式就是
總數(shù)據(jù)數(shù)除以每頁顯示的條數(shù),有余進一。
也就是說10/3=3.3333=4 有余數(shù)就要進一。
*/
$total=mysql_num_rows(mysql_query("select id from table")); //查詢數(shù)據(jù)的總數(shù),id是數(shù)據(jù)庫中的一個自動賦值的字段
$pagenum=ceil($total/$num); //獲得總頁數(shù)
//假如傳入的頁數(shù)參數(shù)大于總頁數(shù),則顯示錯誤信息
If($page$pagenum || $page == 0){
Echo "Error : Can Not Found The page .";
Exit;
}
$offset=($page-1)*$num; //獲取limit的第一個參數(shù)的值,假如第一頁則為(1-1)*10=0,第二頁為(2-1)*10=10。
$info=mysql_query("select name from table limit $offset,$num"); //獲取相應(yīng)頁數(shù)所需要顯示的數(shù)據(jù),name是數(shù)據(jù)里的一個字段
While($it=mysql_fetch_array($info)){
Echo $it['name']."
";
} //顯示數(shù)據(jù)
For($i=1;$i=$pagenum;$i++){
$show=($i!=$page)?"$i":"$i";
Echo $show." ";
}
/*顯示分頁信息,假如是當頁則顯示粗體的數(shù)字,其余的頁數(shù)則為超連接,假如當前為第三頁則顯示如下
1 2 3 4 5 6
*/
?
?php
include("connection.php");
$perNumber=10; //每頁顯示的記錄數(shù)
$page=$_GET['page']; //獲得當前的頁面值
$count=mysql_query("select count(*) from user"); //獲得記錄總數(shù)
$rs=mysql_fetch_array($count);
$totalNumber=$rs[0];
$totalPage=ceil($totalNumber/$perNumber); //計算出總頁數(shù)
if (!isset($page)) {
$page=1;
} //如果沒有值,則賦值1
$startCount=($page-1)*$perNumber; //分頁開始,根據(jù)此方法計算出開始的記錄
$result=mysql_query("select * from user limit $startCount,$perNumber"); //根據(jù)前面的計算出開始的記錄和記錄數(shù)
while ($row=mysql_fetch_array($result)) {
echo "user_id:".$row[0]."br";
echo "username:".$row[1]."br"; //顯示數(shù)據(jù)庫的內(nèi)容
}
if ($page != 1) { //頁數(shù)不等于1
?
a href="fenye.php?page=?php echo $page - 1;?"上一頁/a !--顯示上一頁--
?php
}
for ($i=1;$i=$totalPage;$i++) { //循環(huán)顯示出頁面
?
a href="fenye.php?page=?php echo $i;?"?php echo $i ;?/a
?php
}
if ($page$totalPage) { //如果page小于總頁數(shù),顯示下一頁鏈接
?
a href="fenye.php?page=?php echo $page + 1;?"下一頁/a
?php
}
?
================================
這個是很簡單的..而且也寫了注釋..不知道合不合你的意..
?php
/**
* @author SEPH
* @desc pageft
* @date 2009-4-20
*/
//為了避免重復(fù)包含文件而造成錯誤,加了判斷函數(shù)是否存在的條件:
if(!@function_exists(pageft)){
//定義函數(shù)pageft(),三個參數(shù)的含義為:
//$totle:信息總數(shù);
//$displaypg:每頁顯示信息數(shù),這里設(shè)置為默認是20;
//$url:分頁導(dǎo)航中的鏈接,除了加入不同的查詢信息“page”外的部分都與這個URL相同。
// 默認值本該設(shè)為本頁URL(即$_SERVER["REQUEST_URI"]),但設(shè)置默認值的右邊只能為常量,所以該默認值設(shè)為空字符串,在函數(shù)內(nèi)部再設(shè)置為本頁URL。
function pageft($totle,$displaypg=20,$url=''){
//定義幾個全局變量:
//$page:當前頁碼;
//$firstcount:(數(shù)據(jù)庫)查詢的起始項;
//$pagenav:頁面導(dǎo)航條代碼,函數(shù)內(nèi)部并沒有將它輸出;
//$_SERVER:讀取本頁URL“$_SERVER["REQUEST_URI"]”所必須。
global $page,$firstcount,$pagenav,$_SERVER;
//為使函數(shù)外部可以訪問這里的“$displaypg”,將它也設(shè)為全局變量。注意一個變量重新定義為全局變量后,原值被覆蓋,所以這里給它重新賦值。
$GLOBALS["displaypg"]=$displaypg;
/*if(!$page) $page=1*/;
if(@$_GET['page'])
$page = intval($_GET['page']);
else
$page = 1;
//如果$url使用默認,即空值,則賦值為本頁URL:
if(!$url){ $url=$_SERVER["REQUEST_URI"];}
//URL分析:
$parse_url=parse_url($url);
$url_query=@$parse_url["query"]; //單獨取出URL的查詢字串
if($url_query){
//因為URL中可能包含了頁碼信息,我們要把它去掉,以便加入新的頁碼信息。
//這里用到了正則表達式,請參考“PHP中的正規(guī)表達式”()
$url_query=ereg_replace("(^|)page=$page","",$url_query);
//將處理后的URL的查詢字串替換原來的URL的查詢字串:
$url=str_replace($parse_url["query"],$url_query,$url);
//在URL后加page查詢信息,但待賦值:
if($url_query) $url.="page"; else $url.="page";
}else {
$url.="?page";
}
//頁碼計算:
$lastpg=ceil($totle/$displaypg); //最后頁,也是總頁數(shù)
$page=min($lastpg,$page);
$prepg=$page-1; //上一頁
$nextpg=($page==$lastpg ? 0 : $page+1); //下一頁
$firstcount=($page-1)*$displaypg;
//開始分頁導(dǎo)航條代碼:
$pagenav="顯示第 B".($totle?($firstcount+1):0)."/B-B".min($firstcount+$displaypg,$totle)."/B 條記錄,共 $totle 條記錄BR";
//如果只有一頁則跳出函數(shù):
if($lastpg=1) return false;
$pagenav.=" a href='$url=1' target=_self首頁/a ";
if($prepg) $pagenav.=" a href='$url=$prepg' target=_self前頁/a "; else $pagenav.=" 前頁 ";
if($nextpg) $pagenav.=" a href='$url=$nextpg' target=_self后頁/a "; else $pagenav.=" 后頁 ";
$pagenav.=" a href='$url=$lastpg' target=_self尾頁/a ";
//下拉跳轉(zhuǎn)列表,循環(huán)列出所有頁碼:
$pagenav.=" 到第 select name='topage' size='1' onchange='window.location=\"$url=\"+this.value'\n";
for($i=1;$i=$lastpg;$i++){
if($i==$page) $pagenav.="option value='$i' selected$i/option\n";
else $pagenav.="option value='$i'$i/option\n";
}
$pagenav.="/select 頁,共 $lastpg 頁";
}
}/*沒有用Get傳值*/
?