CSS多級選單
這是一個相當炫的功能,讓網頁看起來像桌面程式,如window的開始選單。實現原理基本和純CSS相簿差不多,但要注意的事項比較多,讓我們一步步來吧。
先來一個非常簡單的一級選單與懸停效果。
<ul id="menu"> <li> <a href="http://www.cnblogs.com/rubylouvre/"> 選單一<!--小圖--><span><!--大圖--></span> </a> </li> <li> <a href="http://www.cnblogs.com/rubylouvre/"> 選單二<!--小圖--><span><!--大圖--></span> </a> </li> <li> <a href="http://www.cnblogs.com/rubylouvre/"> 選單三<!--小圖--><span><!--大圖--></span> </a> </li> <li class="last"> <a href="http://www.cnblogs.com/rubylouvre/"> 選單四<!--小圖--><span><!--大圖--></span> </a> </li> </ul>
結構很熟悉吧,就是把原來放圖片的地方換成文字而已。我還特意標出來了。接著下來的表現層程式碼非常簡單。
* { margin:0; padding:0; } .menu { font-size:12px; } .menu li {/*水平選單*/ float:left; list-style:none; } .menu a { display:block; position:relative; height:32px; width:100px; line-height:32px; background:#a9ea00; color:#ff8040; text-decoration:none; text-align:center; } .menu a:hover { background:#369; color:#fff; } .menu li span { display:none; position:absolute; left:0; top:32px; width:200px; height:150px; background:#B9D6FF; } .menu a:hover span { display:block; }
這裡有兩個值得注意的地方。我們先說第一個。子選單(span元素)的top應該能使其頂部停留在a元素的範圍內,如果包含塊是li元素,同理。當span的top值大於32px,如40px,我們就無法把滑鼠移到span元素上。因為離開了a:hover的作用範圍,span元素又重新隱藏。
.menu li span { display:none; position:absolute; left:0; top:40px;/*★★修改這裡★★*/ width:200px; height:150px; background:#B9D6FF; }
第二個問題是IE6特有的,就是子選單在對應的包含塊mouseout後仍不消失的問題。hover偽類相當於moverover與moverout。我們在可以在mouseover給它的子孫元素認定一種樣式,mouseout時認定另一種。換言之,display現在在IE6無法切換(img元素除外)。解決方法用visibility 代替display。
好了,現在我們真正做二級選單,把有關span的CSS全刪掉,並在結構層原span的位置改為如下程式碼:
<ul> <li><a href="http://www.cnblogs.com/rubylouvre/">二級選單_11</a></li> <li><a href="http://www.cnblogs.com/rubylouvre/">二級選單_12</a></li> </ul>
我們在各遊覽器看一下,感覺非常乏力。IE6與Opera10的二級選單項是垂直的,但我們並沒有清除浮動啊?firefox3.5與chrome與safari4的二級選單項是水平分佈了,但上面好像多出一個選單項……IE8同學這次反而是表現得最好的。我沒有裝IE7,所以一向忽略它。
我們重新設定一下樣式,如把包含塊改設在li元素上,讓二級選單項呈垂直顯示。
* { margin:0; padding:0; } .menu { font-size:12px; } .menu li {/*水平選單*/ float:left; list-style:none; position:relative;/*把包含塊移動li元素*/ } .menu a { display:block; /*position:relative;發現放在a元素中, 在標準遊覽器中慘不忍睹, 和純CSS相簿3的第一個執行框在chrome中遇到的bug一樣*/ height:32px; width:100px; line-height:32px; background:#a9ea00; color:#ff8040; text-decoration:none; text-align:center; } .menu a:hover { background:#369; color:#fff; } /*新增的二級選單部分*/ .menu ul ul { visibility:hidden;/*開始時是隱藏的*/ position:absolute; left:0px; top:32px; } .menu ul a:hover ul{ visibility:visible; } .menu ul ul li { clear:both;/*垂直顯示*/ text-align:left; }
發現二級選單在firefox與safari與chrome中沒有反應,彈不出來(這三個瀏覽器的CSS部分互相抄襲嚴重啊)。opera10表現得最好,IE8其次。不過,標準瀏覽器的所有元素都支援hover偽類,不像IE6,非帶href的a元素不可。我們改寫部分CSS程式碼:
.menu ul li:hover ul,/*非IE6*/ .menu ul a:hover ul{/*IE6*/ visibility:visible; }
二級選單能彈出來了,但那個神秘的li元素也現形了。我用雙重浮動的收縮包圍(shrink-wrapping)現象都無法消除這個神秘的li元素。參考外國的程式碼,方法是,把整個子選單放到a元素的外面,然後用li:hover控制樣式的切換。於是結構層改寫如下:
<div class="menu"> <ul> <li> <a href="http://www.cnblogs.com/rubylouvre/">選單一 </a> <ul> <li><a href="http://www.cnblogs.com/rubylouvre/">二級選單_11</a></li> <li><a href="http://www.cnblogs.com/rubylouvre/">二級選單_12</a></li> </ul> </li> <li> <a href="http://www.cnblogs.com/rubylouvre/">選單二</a> <ul> <li><a href="http://www.cnblogs.com/rubylouvre/">二級選單_21</a></li> <li><a href="http://www.cnblogs.com/rubylouvre/">二級選單_22</a></li> </ul> </li> <li> //***************略************ </li> <li> //***************略************ </li> </ul> </div>
這裡推薦一下我的前端學習qun:784783012,裡面都是學習前端的,如果你想製作酷炫的網頁,想學習程式設計。自己整理了一份2019最全面前端學習資料,從最基礎的HTML+CSS+JS【炫酷特效,遊戲,外掛封裝,設計模式】到移動端HTML5的專案實戰的學習資料都有整理,送給每一位前端小夥伴,有想學習web前端的,或是轉行,或是大學生,還有工作中想提升自己能力的,正在學習的小夥伴歡迎加入學習。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/69901074/viewspace-2646847/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- CSS多級導航選單效果CSS
- CSS 二級下拉選單CSS
- CSS二級下拉選單CSS
- HTML/CSS 二級選單HTMLCSS
- jQuery與CSS二級下拉選單jQueryCSS
- CSS垂直三級導航選單CSS
- Vue 遞迴多級選單Vue遞迴
- elementUI 多級選單動態渲染UI
- CSS三級下拉導航選單詳解CSS
- Java實現多級選單(遞迴)Java遞迴
- 利用純 CSS3 定製單選/多選框樣式CSSS3
- jq 單選多選 && 多選限制
- 輕量級多級選單控制框架程式(C語言)框架C語言
- 【shell 練習5】編寫簡單的多級選單
- Windows登錄檔增加右鍵多級選單Windows
- 單選多選按鈕
- CSS垂直導航選單CSS
- CSS父級選擇器 :has()CSS
- kendoUI 多選下拉選單 kendoMultiSelectUI
- 實現單擊一級選單顯示或隱藏二級選單
- CSS 動態導航選單CSS
- checkbox及css實現點選下拉選單CSS
- MySql樹形結構(多級選單)查詢設計方案MySql
- el-menu使用遞迴元件實現多級選單元件遞迴元件
- 多選單選混合 element-uiUI
- python程式: 三級選單Python
- css滑鼠懸浮下拉選單效果CSS
- CSS導航欄及下拉選單CSS
- HTML+CSS實現下拉選單HTMLCSS
- css中的單選怎麼做CSS
- radio 單選按鈕 選中多個
- JavaScript二級導航選單JavaScript
- JavaScript 省市級聯選單原理JavaScript
- JavaScript 三級導航選單JavaScript
- Python10 三級選單Python
- jquery實現四級級聯下拉選單jQuery
- 純css製作導航下拉選單CSS
- CSS 選擇器前面單雙冒號:CSS