php 進(jìn)階:實(shí)現(xiàn)無(wú)限分類(lèi)第4/4頁(yè)
更新時(shí)間:2006年12月16日 00:00:00 作者:
4.路徑跟蹤
------------------------------------------------------------
前面已經(jīng)介紹過(guò)了分類(lèi)的創(chuàng)建實(shí)現(xiàn)方法,在分類(lèi)表里記載了 rout_id 和 rout_char 這兩個(gè)存儲(chǔ)分類(lèi)路徑的信息,在不做任何處理的情況下,程序只能夠順序下到最底層的分類(lèi)而無(wú)法倒退(當(dāng)然可利用瀏覽器的 back 鍵倒退,但這對(duì)程序來(lái)說(shuō)是不完整的),因此必須將 rout_id 和 rout_char 的信息分解出來(lái)完成實(shí)在的路徑指示.
具體的做法,假如數(shù)據(jù)庫(kù)記載了這么一條分類(lèi)信息:
id:4
uid:2
type:開(kāi)發(fā)工具
rout_id:0:1:2:4
rout_char:系統(tǒng):linux:開(kāi)發(fā)工具
當(dāng)程序走到分類(lèi)'開(kāi)發(fā)工具'上時(shí),除了要求顯示路徑信息外還要求能夠去到路徑上的任一分類(lèi)中,該怎么做能?這里就需要用到 explode() 函數(shù)了.因?yàn)?nbsp;rout_id 和 rout_char 是對(duì)應(yīng)關(guān)系的,所以可將它們分解:
$path=explode(":",$rout_id);
$path_gb=explode(":",$rout_char);
這時(shí)所有分類(lèi)信息都被分解了,現(xiàn)在要做的就是以鏈接的方式還原路徑信息:
for ($i=0;;$i++) {
$a=$i+1;
echo "<a
href=$php_self?func=showtype&uid=",$path[$a],">",$path_gb[$i],"</a>:";
if (empty($path_gb[$i])) {
break;
}
}
上面這段代碼就實(shí)現(xiàn)了加鏈接還原路徑的功能,因?yàn)閷?shí)現(xiàn)的是無(wú)限分類(lèi),因此是沒(méi)有上限的,所以在 for($i=0;;$i++) 里沒(méi)有范圍限制,而設(shè)置循環(huán)退出的條件是 $path_gb[$i] 中的值為空,將這段代碼插入類(lèi)別顯示版面的程序塊內(nèi)就行了:
<?
.....
.....
//顯示分類(lèi)************************************************
if ($func=='showtype'):
echo "<table>";
//判斷分類(lèi)的狀態(tài)
if ($uid!=0) {
$result=mysql_query("select * from type where id=$uid");
$type=mysql_result($result,0,"type");
//******** 新加入的代碼 ***************
$rout_id=mysql_result($result,0,"rout_id");
$rout_char=mysql_result($result,0,"rout_char");
$path=explode(":",$rout_id);
$path_gb=explode(":",$rout_char);
echo "<tr><td>";
for ($i=0;;$i++) {
$a=$i+1;
echo "<a
href=$php_self?func=showtype&uid=",$path[$a],">",$path_gb[$i],"</a>:";
if (empty($path_gb[$i])) {
break;
}
}
echo "</td></tr>";
//******** end ***********************
} else {
$type='父分類(lèi)';
}
echo "<tr><td><a href='$php_self?func=createtype&uid=$uid'>創(chuàng)建分類(lèi)</a></td></tr>";
echo "<tr><td>$type</td></tr>";
$result=mysql_query("select * from type where uid=$uid");
$num=mysql_numrows($result);
if (!empty($num)) {
for ($i=0;$i<$num;$i++) {
$id=mysql_result($result,$i,"id");
$type=mysql_result($result,$i,"type");
echo "<tr><td>";
echo "<a href='$php_self?func=showtype&uid=$id'>$type</a>";
echo "</td></tr>";
}
}
echo "</table>";
endif; /* end showtype */
.....
.....
?>
完成這個(gè)功能塊后,就可繼續(xù)分類(lèi)信息的顯示實(shí)現(xiàn)了...
您可能感興趣的文章:
- php無(wú)限分類(lèi)且支持輸出樹(shù)狀圖的詳細(xì)介紹
- 利用php遞歸實(shí)現(xiàn)無(wú)限分類(lèi) 格式化數(shù)組的詳解
- PHP無(wú)限分類(lèi)(樹(shù)形類(lèi))的深入分析
- 基于php無(wú)限分類(lèi)的深入理解
- 比較簡(jiǎn)單實(shí)用的PHP無(wú)限分類(lèi)源碼分享(思路不錯(cuò))
- PHP 無(wú)限分類(lèi)三種方式 非函數(shù)的遞歸調(diào)用!
- PHP無(wú)限分類(lèi)代碼,支持?jǐn)?shù)組格式化、直接輸出菜單兩種方式
- 一個(gè)很簡(jiǎn)單的無(wú)限分類(lèi)樹(shù)實(shí)現(xiàn)代碼
- php遞歸實(shí)現(xiàn)無(wú)限分類(lèi)生成下拉列表的函數(shù)
- php用數(shù)組返回?zé)o限分類(lèi)的列表數(shù)據(jù)的代碼
- 刪除無(wú)限分類(lèi)并同時(shí)刪除它下面的所有子分類(lèi)的方法
- php 無(wú)限分類(lèi)的樹(shù)類(lèi)代碼
- 自己前幾天寫(xiě)的無(wú)限分類(lèi)類(lèi)
- 帖幾個(gè)PHP的無(wú)限分類(lèi)實(shí)現(xiàn)想法~
- PHP無(wú)限分類(lèi)的類(lèi)
- 解析thinkphp的左右值無(wú)限分類(lèi)
相關(guān)文章
PHP用mysql_insert_id()函數(shù)獲得剛插入數(shù)據(jù)或當(dāng)前發(fā)布文章的ID
向mysql 插入數(shù)據(jù)時(shí),很多時(shí)候我們想知道剛剛插入數(shù)據(jù)的id,這對(duì)我們很有用。下面這篇文章就詳細(xì)給大家介紹了利用mysql_insert_id()函數(shù)獲得剛插入數(shù)據(jù)或當(dāng)前發(fā)布文章的ID,有需要的朋友們可以參考借鑒,感興趣的朋友們下面來(lái)一起看看吧。2016-11-11PHP7 preg_replace 出錯(cuò)及解決辦法
在本篇文章里小編給大家整理的是一篇關(guān)于PHP7 preg_replace 出錯(cuò)及解決辦法,有需要的朋友們可以跟著學(xué)習(xí)下。2021-12-12簡(jiǎn)單的方法讓你的后臺(tái)登錄更加安全(php中加session驗(yàn)證)
通過(guò)特定文件為后臺(tái)入口注冊(cè)session,否則失敗退出。即直接使用原后臺(tái)地址將無(wú)法登錄后臺(tái)。這樣一來(lái),入口文件名的多樣性、可變更性將為你的后臺(tái)登錄提供更加安全的環(huán)境2012-08-08redirect_uri參數(shù)錯(cuò)誤的解決方法(必看)
下面小編就為大家?guī)?lái)一篇redirect_uri參數(shù)錯(cuò)誤的解決方法(必看)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-02-02php+html優(yōu)化頁(yè)面顯示速度的方法小結(jié)
這篇文章主要為大家詳細(xì)介紹了php結(jié)合html優(yōu)化頁(yè)面顯示速度的一些常見(jiàn)方法,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-12-12php超快高效率統(tǒng)計(jì)大文件行數(shù)
這篇文章主要介紹了php超快高效率統(tǒng)計(jì)大文件行數(shù)的相關(guān)資料,需要的朋友可以參考下2015-07-07