jquery 樹形導航菜單無限級

来源:https://www.cnblogs.com/Byme/archive/2018/05/11/9026751.html
-Advertisement-
Play Games

轉自:http://www.jb51.net/article/71615.htm 侵刪 Document --> ...


轉自:http://www.jb51.net/article/71615.htm 侵刪
<!
DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> <style type="text/css"> body{ padding:0; margin:0; } ul{ padding: 0; margin:0; } .navlist { /*margin-left: -30px;*/ } .navlist div { padding-left: 15px; } .navlist div ul { overflow: hidden; display: none; height: auto; } .navlist span { display: block; height: 25px; line-height: 25px; padding-left: 5px; margin: 1px 0; cursor: pointer; border-bottom: 1px solid #CCC; } .navlist span:hover { background-color: #e6e6e6; color: #cf0404; } .navlist a { color: #333; text-decoration: none; } .navlist a:hover { color: #06F; } .btn { height: 30px; margin-top: 10px; border-bottom: 1px solid #CCC; } </style> </head> <div class="btn"> <input name="" type="button" id="btn_open" value="全部展開" /> <input name="" type="button" id="btn_close" value="全部收縮" /> </div> <div id="navlist" class="navlist"></div> <body> <!-- <div id="menu"></div> --> <script src="https://cdn.bootcss.com/jquery/1.9.1/jquery.min.js"></script> <script type="text/javascript"> var json = [{ "id": 1, "name": "系統管理", // 菜單名稱 "url": "#", //映射URL "icon": "sys-icon", //圖標樣式 "pid": 0, //父菜單ID "items": [] }, { "id": 1, "name": "系統管理1", // 菜單名稱 "url": "#", //映射URL "icon": "sys-icon", //圖標樣式 "pid": 0, //父菜單ID "items": null }, { "id": 5, "name": "測試菜單1", "url": "#", "icon": "sys-icon", "pid": 1, "items": [{ "name": "測試菜單1-1", "url": "#", //映射URL }, { "name": "測試菜單1-2", "items": [{ "name": "測試菜單1-2-1", "url": "#", //映射URL }, { "name": "測試菜單1-2-2", "url": "#", //映射URL }, { "name": "測試菜單1-2-3", "url": "#", //映射URL }] }, ] }, { "id": 5, "name": "測試菜單2", "url": "#", "icon": "sys-icon", "pid": 1, "items": [{ "name": "測試菜單2-1", "url": "#", //映射URL }, { "name": "測試菜單2-2", "url": "#", //映射URL }] }, { "name": "測試菜單3", "items": [{ "name": "測試菜單3-1", "url": "#", //映射URL items: [{ "name": "測試菜單3-1-1", "url": "#", //映射URL }] }, { "name": "測試菜單3-2", "url": "#", //映射URL items: [{ "name": "測試菜單3-2-1", "url": "#", //映射URL }] }, { "name": "測試菜單3-3", "url": "#", //映射URL }] }, { "name": "測試菜單4", }, { "name": "測試菜單5", }] console.log(json) /*遞歸實現獲取無級樹數據並生成DOM結構*/ var str = ""; var forTree = function(o) { for (var i = 0; i < o.length; i++) { var urlstr = ""; try { if (typeof o[i]["url"] == "undefined") { urlstr = "<div><span>" + o[i]["name"] + "</span><ul>"; } else { urlstr = "<div><span><a href=" + o[i]["url"] + ">" + o[i]["name"] + "</a></span><ul>"; } str += urlstr; if (o[i].items != null) { forTree(o[i].items); } str += "</ul></div>"; } catch (e) {} } // console.log(str); return str; } /*添加無級樹*/ document.getElementById("navlist").innerHTML = forTree(json); /*樹形菜單*/ var menuTree = function() { //給有子對象的元素加[+-] $("#navlist ul").each(function(index, element) { // console.log(index, element); var ulContent = $(element).html(); var spanContent = $(element).siblings("span").html(); if (ulContent) { $(element).siblings("span").html("[+] " + spanContent) } }); $("#navlist").find("div span").click(function() { var ul = $(this).siblings("ul"); var spanStr = $(this).html(); var spanContent = spanStr.substr(3, spanStr.length); if (ul.find("div").html() != null) { if (ul.css("display") == "none") { ul.show(300); $(this).html("[-] " + spanContent); } else { ul.hide(300); $(this).html("[+] " + spanContent); } } }) }() /*展開*/ $("#btn_open").click(function() { $("#navlist ul").show(300); curzt("-"); }) /*收縮*/ $("#btn_close").click(function() { $("#navlist ul").hide(300); curzt("+"); }) function curzt(v) { $("#navlist span").each(function(index, element) { var ul = $(this).siblings("ul"); var spanStr = $(this).html(); var spanContent = spanStr.substr(3, spanStr.length); if (ul.find("div").html() != null) { $(this).html("[" + v + "] " + spanContent); } }); } </script> </body> </html>

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • https://msdn.microsoft.com/zh-cn/library/ms189822(v=sql.120).aspx Microsoft SQL Server 將保留關鍵字用於定義、操作和訪問資料庫。 保留關鍵字是 SQL Server 使用的 Transact-SQL 語言語法的一部 ...
  • 缺點:後期升級不方便,生產中建議RPM包方式安裝 CentOS7預設安裝了和MySQL有相容性的MariaDB資料庫,在我們安裝MySQL5.7之前為了避免發生衝突首先刪除MariaDB。 一、基於官方源碼包安裝 下載 mysql-5.7.22.tar.gz 安裝cmake # yum -y ins ...
  • 學習目標 確定是否需要執行恢復 訪問不同的界面(如Enterprise Manager和命令行) 描述並使用可用的方案,如Recovery Manager(RMAN)和數據恢復指導 對以下文件執行恢復 -控制文件 -重做日誌文件 -數據文件 打開資料庫 要打開資料庫,必須滿足以下條件 -所有控制文件 ...
  • NoHttp的Cookie管理原理 在文檔的初始化配置一章講了NoHttp如何配置或者禁用cookie自動管理。 NoHttp的Cookie自動維護,嚴格遵守Http協議,即區分臨時Cookie和有效期Cookie。 臨時Cookie在本次App運行期內一直有效,直到App被殺死即被清除。 有效期C ...
  • 新手博友,多多關照 下麵給大家介紹JDK Eclipse AndroidSDK ADT環境搭建,安裝教程 第一步、安裝JDK; 第二步、安裝Eclipse; 第三步、下載並安裝AndroidSDK; 第四步、為Eclipse安裝ADT插件 第一步,安裝JDK 首先複製鏈接(http://www.or ...
  • 內容來自:https://www.cnblogs.com/mnstar/p/6281886.html ...
  • 一.創建私有庫的流程簡介 創建一個項目,留著後面的流程3製作私有庫 在可以創建私有庫的地方創建一個code repository, code repository是代碼倉庫,我們把代碼上傳到這個倉庫。 在可以創建私有庫的地方創建一個spec repository, spec repository是配 ...
  • 函數預設值是一個很提高魯棒性的東西(就是讓程式更健壯)MDN關於函數預設參數的描述:函數預設參數允許在沒有值或undefined被傳入時使用預設形參。 ES5 使用邏輯或||來實現 眾所周知,在ES5版本中,並沒有提供的直接方法供我們我們處理函數預設值所以只能夠自己去增強函數的功能,一般會這麼來做: ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...