使用jquery實現的多級樹形菜單代碼實例

来源:http://www.cnblogs.com/zhadanren/archive/2016/01/16/5136200.html
-Advertisement-
Play Games

使用jquery實現的多級樹形菜單代碼實例:樹形菜單在網站中有大量的應用,這當然是因為它的獨特優點,首先它可以有效的組織數據,使分類更為清晰明瞭,通常情況下樹形菜單是可以摺疊的,這樣可以以更小的空間容納更多的數據,下麵就詳細介紹一個使用jquery實現的屬性菜單。代碼實例如下:螞蟻部落 KPI考核....


使用jquery實現的多級樹形菜單代碼實例:
樹形菜單在網站中有大量的應用,這當然是因為它的獨特優點,首先它可以有效的組織數據,使分類更為清晰明瞭,通常情況下樹形菜單是可以摺疊的,這樣可以以更小的空間容納更多的數據,下麵就詳細介紹一個使用jquery實現的屬性菜單。
代碼實例如下:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta name="author" content="http://www.softwhy.com/" />
<title>螞蟻部落</title>
<style type="text/css">
h1, h2, h3, h4, h5, p, dl, dt, dd, ul, ol, li, input, img, body, button, form, table{
  margin:0;
  padding:0;
  border:0;
  list-style:none;
  font-size:12px;
  font-weight:normal
}
a{text-decoration:none}
a:link, a:visited{color:#333}
a:hover{background:#FC9}
.aside{
  width:163px;
  padding-left:10px
}
.aside h2{
  font-size:16px;
  padding-left:15px
}
.all{background:url(mytest/jQuery/bg_02.gif) no-repeat 0 6px;}
.all1{background:url(mytest/jQuery/bg_02.gif) no-repeat 0 -41px}
.box{background:url(mytest/jQuery/bg_02.gif) no-repeat 0 10px;}
.box1{background:url(mytest/jQuery/bg_02.gif) no-repeat 0 -37px}
.aside ul{margin-left:15px}
.aside li{
  display:none;
  height:24px;
  line-height:24px;
  margin-left:26px
}
.aside .bold{
  display:block;
  font-size:14px;
  height:30px;
  line-height:30px;
  padding-left:15px
}
</style>
<script type="text/javascript" src="mytest/jQuery/jquery-1.8.3.js"></script>
<script type="text/javascript">
$(document).ready(function(){
  $('.all1').toggle(function(){
    $(this).removeClass('all1').addClass('all').siblings('.myUl').slideUp();
  },function(){
    $(this).removeClass('all').addClass('all1').siblings('.myUl').slideDown();
  });
  $('.box').toggle(function(){
    $(this).removeClass('box').addClass('box1');
  },function(){
    $(this).removeClass('box1').addClass('box');
  });
  $('.bold').toggle(function(){
    $(this).siblings().slideDown(); 
  },function(){
    $(this).siblings().slideUp(); 
  })  
})
</script>
</head>
<body>
<div class="aside">
  <h2 class="all1">KPI考核指標</h2>
  <ul class="myUl">
    <span class="bold box">當月考核結果</span>
    <li><a href="" title="" alt="">日考核結果跟蹤</a></li>
    <li><a href="" title="" alt="">日考核扣分分析</a></li>
    <li><a href="" title="" alt="">日扣分占比分析</a></li>
    <li><a href="" title="" alt="">月扣分占比分析</a></li>
    <li><a href="" title="" alt="">考核異常跟蹤</a></li>
  </ul>
  <ul class="myUl">
    <span class="bold box">年累計考核結果</span>
    <li><a href="" title="" alt="">月考核結果跟蹤</a></li>
    <li><a href="" title="" alt="">年累計扣分分析</a></li>
    <li><a href="" title="" alt="">扣分占比分析</a></li>
  </ul>
  <ul class="myUl">
    <span class="bold box">數據統計</span>
    <li><a href="" title="" alt="">考核指標環比分析</a></li>
    <li><a href="" title="" alt="">考核指標扣分占比分析</a></li>
    <li><a href="" title="" alt="">考核指標趨勢分析</a></li>
    <li><a href="" title="" alt="">考核指標排名分析</a></li>
    <li><a href="" title="" alt="">考核指標同比分析</a></li>
  </ul>
</div>
</body>
</html>

以上代碼實現了我們的要求,可以實現屬性菜單的摺疊和展開效果,下麵介紹一下它的實現過程。
一.實現原理:
1.摺疊和展開圖標的切換:
摺疊和展開圖標其實是在一張背景圖上,當點擊的時候,通過控制背景圖片的位置就實現了切換效果,具體可以參閱CSS的background-position定位詳解一章節。
2.菜單的摺疊和隱藏:
菜單的摺疊和隱藏主要是控制標題元素的兄弟元素的隱藏和顯示實現的,這裡不多介紹了,可以參閱相關閱讀。
二.代碼註釋:
1.$(document).ready(function(){}),文檔結構完全載入完畢再去執行函數中的代碼。
2.$('.all1').toggle(function(){},function(){}),點擊元素切換函數的執行。
3.$(this).removeClass('all1').addClass('all').siblings('.myUl').slideUp(),這是一個鏈式調用,首先會移出當前點擊元素上的樣式class屬性all1,然後為再為其添加樣式class屬性all,然後將它的同輩元素中class屬性值為myUl的元素收縮隱藏,一句話,這段代碼實現了點擊一級樹,實現二級數樹隱藏效果。
4.$(this).removeClass('all').addClass('all1').siblings('.myUl').slideDown(),此代碼和上面的作用相反,點擊一級樹,實現二級數的顯示效果。下麵代碼功能都是類似的,這裡就不多介紹了。
三.相關閱讀:
1.toggle()可以參閱jQuery的toggle()方法一章節。 
2.removeClass()函數可以參閱jQuery的removeClass()方法一章節。 
3.addClass()函數可以參閱jQuery的addClass()方法一章節。 
4.siblings()函數可以參閱jQuery的siblings()方法一章節。 
5.slideUp()函數可以參閱jQuery的slideUp()方法一章節。 
6.slideDown()函數可以參閱jQuery的slideDown()方法一章節。
 

原文地址是:http://www.softwhy.com/forum.php?mod=viewthread&tid=11817

更多內容可以參閱:http://www.softwhy.com/jquery/


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

-Advertisement-
Play Games
更多相關文章
  • 純css實現的截取字元串後面添加省略號代碼實例:通常情況下截取字元串使用後臺語言或者javascript,當然本人頁推薦使用上述方式,因為更加準確靈活。不過使用純css也可以實現截取字元串,多餘的用省略號替代的效果。代碼如下:螞蟻部落 螞蟻部落歡迎您,只有努力奮鬥才會有美好的未來。 沒有人一開始.....
  • jQuery清除表單數據代碼實例:清除表單中的數據最簡單的方法,就是點擊重置按鈕實現清空效果,但是在實際應用中可能需要根據代碼的具體運行情況來清除表單中的數據,下麵就分享一段能夠實現此功能的jQuery代碼。function clearForm(form) { $(':input', form).....
  • javascript模擬實現函數重載:函數重載功能必須要模擬實現,因為本身並不具備,關於函數重載的概念這裡就不多介紹了,因為不知道何為重載,那麼本章節也就沒有任何意義了,下麵先看一段代碼實例:function func(){alert("螞蟻部落");}function func(num){aler...
  • 調整視窗大小也能夠實現div水平垂直居中代碼實例:將一個div在視窗內實現居中效果,基本上沒有什麼難度,具體可以參閱CSS實現div屏幕居中效果代碼一章節。但是有時候我們可能會有這樣的需求,就是在調整視窗大小的情況下也能夠實現div垂直水平居中效果,下麵通過代碼實例做一下簡單介紹,代碼如下: ...
  • jQuery實現點擊回車執行指定代碼:回車鍵只要用過電腦的就再熟悉不過了,通常來講點擊回車會執行特定的操作,比如進入一個界面或者一個應用程式,下麵就介紹一下使用jQuery實現的點擊回車指定指定的代碼。代碼如下:$("#thebt").keydown(function(e){ if (e.whi.....
  • js倒計時關閉當前頁面代碼:很多網站在關閉網頁之前會給出一個倒計時效果,這樣可以讓瀏覽者做到根據相應的情況進行操作,比較人性化,下麵就通過實例代碼介紹一下如何實現此效果。代碼實例如下:螞蟻部落以上代碼實現了我們想要的功能,可以倒計時10秒之後關閉頁面。原理非常的簡單,就是利用定時器函數setInte...
  • 1.CSS overflow 屬性2.標簽 標簽用於搜集用戶信息。1 type屬性根據不同的 type 屬性值,輸入欄位擁有很多種形式。可以是文本欄位、覆選框、掩碼後的文本控制項、單選按鈕、按鈕等等。text:文本區域 readonly屬性:是否只讀。password:密碼區域,輸入的文本以'*...
  • 相容低版本IE瀏覽器的背景顏色漸變效果:大多數的相容性問題都是由於低版本的IE瀏覽器所導致的,本章節分享一段代碼實例,它能夠實現背景的顏色的漸變效果,如果在標準瀏覽器中直接採用css3屬性即可實現,但是IE低版本的問題所以需要進行一下相容性處理。代碼如下:螞蟻部落上面的代碼實現了我們的要求,標準瀏覽...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...