一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

php實現無限級分類實現代碼(遞歸方法)

開始以為這樣的功能似乎很難,之前也做過一個百科的東西,其中也涉及到了分類的功能,不過不是無限級的分類,而是簡單的實現了固定的三級分類,當時是自己設計的,想在想起來實現方法太土了,其實三級分類也只是無限級分類的一種特殊情況而已嘛。經過一段時間考慮,已經有了一些眉目,到網上一查,原來這樣的東西鋪天蓋地,呵呵。其實無限級下拉列表功能是很簡單的,無非就是用一個遞歸算法就好啦。
首先要設計數據庫,需要建一個表,里面存儲分類信息,至少需要3個字段,第一個是主鍵(ID),第二個是父級分類ID(parentid),第三個是分類的名稱(classname)。可能的一種效果是:
ID PARENTID CLASSNAME
1 0 一級分類A
2 0 一級分類B
3 1 二級分類A
4 1 二級分類B
主要思路:首先看第三行和第四行,父類ID(PARENTID)的值是1,表示屬于id=1這個類的子類,而,一,二兩行因為是一級分類,沒有上級分類,所以父類ID(PARENTID)的值是0,表示初級分類,依次類推便實現了無限級分類。最終的效果是:
├一級分類A
├─┴二級分類A
├─┴二級分類B
├一級分類B
然后就是程序,這里以php作為描述語言,可以很方便的改成其他語言,因為原理相似,就是一個遞歸而已。
復制代碼 代碼如下:
<?php
$dbhost = "localhost"; // 數據庫主機名
$dbuser = "root"; // 數據庫用戶名
$dbpd = "123456"; // 數據庫密碼
$dbname = "test"; // 數據庫名
mysql_connect($dbhost,$dbuser,$dbpd); //連接主機
mysql_select_db($dbname); //選擇數據庫
mysql_query("SET NAMES 'utf8'");
display_tree("├",0);
function display_tree($tag,$classid) {
$result = mysql_query("
SELECT *
FROM ylmf_class
WHERE parentid = '" . $classid . "'
;"
);
while ($row = mysql_fetch_array($result)) {
// 縮進顯示節點名稱
echo $tag.$row['classname'] . "<br/>";
//再次調用這個函數顯示子節點的子節點
display_tree($tag."─┴",$row['id']);
}
}
?>

這樣遞歸方法,對于大量的子欄目是個負擔,一些成熟的cms系統。都是生產數組方便調用,也能大幅的提高效率。

php技術php實現無限級分類實現代碼(遞歸方法),轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 国产乱子伦露脸在线 | 韩国美女免费网站视频 | 久久厕所精品国产精品亚洲 | 亚洲国产精久久久久久久 | 欧美精品一国产成人性影视 | 欧美综合视频在线观看 | 看免费5xxaaa毛片30厘米 | 久久综合久久久久 | 青青草91视频 | 国产成人咱精品视频免费网站 | 久久综合久 | 亚洲一区二区三区麻豆 | 无码中文字幕日韩专区 | 久久综合丝袜日本网 | 欧美在线一二三区 | 中文字幕日本不卡一二三区 | 9ⅰ视频在线播放 | 爽天天天天天天天 | 久久精品国产2020观看福利色 | 免费观看国产一区二区三区 | 91美女视频在线 | 免费国产视频 | 玖玖精品视频 | 久久婷婷五夜综合色频 | 精品国产一区二区三区成人 | 99在线国产视频 | 国产精品久久久久亚洲 | 国产午夜视频 | 夜夜五月天 | 久草五月天 | 福利影院在线看 | 伊人久久网国产伊人 | 一色屋成人免费精品网 | 日本一区二区三区在线 观看网站 | 黄色美女视频网站 | 亚洲情综合五月天 | 久久线看观看精品香蕉国产 | 欧美成人免费大片888 | 欧美国产片 | 最新香蕉97超级碰碰碰碰碰久 | 色视频在线观看免费 |