|
|
|
|
|
|
本文介紹一個左側導航菜單,這個導航菜單是可折疊的,并且它可以在左側縮進和伸展。這個導航菜單適合很多應用環境。
效果如圖

示例介紹
本示例由CSS+JavaScript實現。
HTML代碼
<div id="ensconce">
<h2>
<img src="static/show.png">
國內各地景點
</h2>
</div>
<div id="open">
<div class="navH">
國內各地景點
<span><img class="obscure" src="static/obscure.png"></span>
</div>
<div class="navBox">
<ul>
<li>
<h2 class="obtain">北京景點<i></i></h2>
<div class="secondary">
<h3>故宮</h3>
<h3>十三陵</h3>
<h3>圓明園</h3>
<h3>長城</h3>
<h3>雍和宮</h3>
<h3>天壇公園</h3>
</div>
</li>
<li>
<h2 class="obtain">南京景點<i></i></h2>
<div class="secondary">
<h3>棲霞寺</h3>
<h3>夫子廟</h3>
<h3>海底世界</h3>
<h3>中山陵</h3>
<h3>烏衣巷</h3>
<h3>音樂臺</h3>
</div>
</li>
</ul>
</div>
</div>
這個HTML結構比較清晰易理解。有兩個并列的外層div,前一個是<div id="ensconce">...</div>,后一個是<div id="open">...</div>,前一個是隱藏菜單后顯示的div,后一個是顯示菜單后的div。
<h2 class="obtain">...</h2>是菜單項目,點擊它后展開或折疊其對應的<div class="secondary">...</div>里面的<h3>...</h3>菜單。
JavaScript
本示例包含兩個兩個JS文件。
<script src="static/adapter.js"></script>
<script src="static/menu.js"></script>
adapter.js是實現文字和標簽的大小隨著屏幕的尺寸做變話 等比縮放的功能,而menu.js是實現導航菜單的點擊事件。具體編程請看程序里的注釋文字。
CSS
本示例包含兩個CSS文件。
<link rel="stylesheet" href="static/base.css">
<link rel="stylesheet" href="static/menu.css">
base.css是全局樣式設置,而menu.css是菜單的樣式設置。
#menu{...}是菜單的區域樣式設置。這里設置高度(height)是100%,而 float:left; 是設置菜單區域在左側,user-select:none; 是禁止文本復制粘貼。
#menu {
overflow: hidden;
height: 100%;
float: left;
-webkit-touch-callout: none;
-webkit-user-select: none;
-khtml-user-select: none;
-moz-user-select: none;
-ms-user-select: none;
user-select: none;
}#menu #ensconce { ... } 是隱藏菜單后顯示的div樣式,而 #menu #ensconce h2 { ... } 是設置該div區域內文字的樣式。
#menu #open { ... } 是設置導航菜單區域div打開的樣式。
#menu #open .navH 設置導航菜單的頭部位置及文字等樣式。
#menu #open .navBox 設置導航菜單項目的區域,包括位置、高寬、文字等樣式。
總結
本文介紹了CSS+JS實現可伸縮可折疊的左邊側欄項目導航菜單,這個導航菜單很大眾化,并且其界面設計大氣不花俏,應用場景很廣。喜歡的朋友可直接收藏本頁,或直接下載源碼保存備用。
相關文章
