首頁 >web前端 >js教程 >JavaScript遞迴演算法介紹

JavaScript遞迴演算法介紹

巴扎黑
巴扎黑原創
2017-08-18 09:52:261305瀏覽

這篇文章主要介紹了JavaScript遞歸演算法產生樹狀選單,具有一定的參考價值,有興趣的小夥伴們可以參考一下

本文實例為大家分享了js產生樹狀選單的具體程式碼,供大家參考,具體內容如下

1、最終效果圖(這裡僅為實作演算法,並載入至頁面,不做任何css介面優化)

註解:本範例包含三級目錄選單,但實際上可支援N級(可使用程式碼自行測試)

2、資料來源

選單資訊一般來自資料庫中資料表,且為自連接表,其中包含主要欄位(主鍵,選單名稱,父級id);

本範例在前端頁面中使用物件陣列模擬從資料庫取得選單資訊;


var menuArry = [
{ id: 1, name: "办公管理", pid: 0 },
{ id: 2, name: "请假申请", pid: 1 },
{ id: 3, name: "出差申请", pid: 1 },
{ id: 4, name: "请假记录", pid: 2 },
{ id: 5, name: "系统设置", pid: 0 },
{ id: 6, name: "权限管理", pid: 5 },
{ id: 7, name: "用户角色", pid: 6 },
{ id: 8, name: "菜单设置", pid: 6 },
]; 

註解:id——選單主鍵id;name——選單名稱;pid——父級id

3、程式設計

選單資訊一般來源


#
//菜单列表html
    var menus = '';
 
    //根据菜单主键id生成菜单列表html
    //id:菜单主键id
    //arry:菜单数组信息
    function GetData(id, arry) {
      var childArry = GetParentArry(id, arry);
      if (childArry.length > 0) {
        menus += &#39;<ul>&#39;;
        for (var i in childArry) {
          menus += &#39;<li>&#39; + childArry[i].name;
          GetData(childArry[i].id, arry);
          menus += &#39;</li>&#39;;
        }
        menus += &#39;</ul>&#39;;
      }
    }
 
    //根据菜单主键id获取下级菜单
    //id:菜单主键id
    //arry:菜单数组信息
    function GetParentArry(id, arry) {
      var newArry = new Array();
      for (var i in arry) {
        if (arry[i].pid == id)
          newArry.push(arry[i]);
      }
      return newArry;
    }

註解:本範例選單使用ul無序列表演示,menus變數為最終產生的選單html

4、運行


GetData(0, menuArry)
$("body").append(menus);

註解:GetData(0, menuArry), 0——頂層選單主鍵

5、完整程式碼


#



  
  
  


 
  

以上是JavaScript遞迴演算法介紹的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn