色尼玛亚洲综合影院,亚洲3atv精品一区二区三区,麻豆freexxxx性91精品,欧美在线91

一個更簡單的無限級分類菜單代碼

首先要感謝terry39的指點,元旦閑來無事,我就把他所講的原理簡單實現(xiàn)一下,這個程序的關(guān)鍵就在于數(shù)據(jù)表的設(shè)計很有特色,不用遞歸,依靠個簡單SQL語句就能列出菜單,看看這個數(shù)據(jù)表怎么設(shè)計的:
數(shù)據(jù)庫字段大概如下:
-----------------------------------------------------------------------------------
id              編號
fid             父分類編號
name         分類名
path          分類路徑,以 id 為節(jié)點,組成類似    ,1,2,3,4, 這樣的字符串
----------------------------------------------------------------------------------

可以假設(shè)有如下的數(shù)據(jù)

id      fid          name             path
----------------------------------------------------
1       0           分類1             ,1,
2       0           分類2             ,2,
3       1           分類1-1          ,1,3,
4       1           分類1-2          ,1,4,
5       2           分類2-1          ,2,5,
6       4           分類1-2-1       ,1,4,6,
----------------------------------------------------
這次偷懶,我只用一個頁面,好在代碼不長,全部代碼用類封裝的(不是必要,而是自己也想熟悉一下OO,呵呵!),來看看頁面代碼:
復(fù)制代碼 代碼如下:
<?php

/**************************************

  頁面:menu.php
  作者:輝老大
  功能:定義數(shù)據(jù)庫操作及生成菜單列表類

**************************************/
class menu{

       //創(chuàng)建構(gòu)造函數(shù),作用:數(shù)據(jù)庫連接并選擇相應(yīng)數(shù)據(jù)庫
       public function __construct(){
           $dbhost     = "localhost";
           $dbuser     = "root";
           $dbpassword = "7529639";
           $dbname     = "menu";
           mysql_connect($dbhost,$dbuser,$dbpassword) or die("error!");
           mysql_query("SET NAMES 'GBK'");
           mysql_select_db($dbname);
       }

       //執(zhí)行SQL語句函數(shù)
       private function query($sql){
           return mysql_query($sql);
       }

       //取得結(jié)果集數(shù)組函數(shù)
       private function loop_query($result){
           return mysql_fetch_array($result);
       }
       //列出菜單列表函數(shù)
       public function menulist(){
           $sql="select * from list order by path";
           $result=$this->query($sql);
            while($rows=$this->loop_query($result)){
             if(substr_count($rows['path'],',')>2){
               for($i=0;$i<(substr_count($rows['path'],',')-2);$i++)
               echo ' ';
              }
             echo $rows['name'].'<br>';
            }
       }

       //創(chuàng)建析構(gòu)函數(shù),作用:關(guān)閉數(shù)據(jù)庫連接
       public function __destruct(){
           return mysql_close();
       }
   }
  $db=new menu();//生成實例
  $db->menulist();//調(diào)用方法生成菜單
?> 

php技術(shù)一個更簡單的無限級分類菜單代碼,轉(zhuǎn)載需保留來源!

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

主站蜘蛛池模板: 凤翔县| 丰原市| 德州市| 安陆市| 湾仔区| 穆棱市| 大同县| 略阳县| 靖西县| 宜城市| 孟连| 平潭县| 徐水县| 晋城| 大名县| 中牟县| 鹿邑县| 资兴市| 攀枝花市| 霍山县| 防城港市| 海门市| 延寿县| 商丘市| 安龙县| 庆阳市| 肃北| 南丹县| 东乡县| 永春县| 资溪县| 开江县| 蓬安县| 淮安市| 库尔勒市| 县级市| 夏邑县| 绥江县| 富平县| 崇明县| 平遥县|