|
編寫純 CSS 彈出菜單的原理及實現 By shawl.qiu
摘要:
本文介紹了使用 CSS 編寫適用于 Opera, Firefox, IE 的多風格彈出菜單
說明:
編寫 CSS 彈出菜單的要點不外乎當鼠標移到目標上時, 顯示出隱藏的標簽.
要隱藏的標簽使用 display:none; 屬性進行隱藏.
觸發顯示隱藏標簽主要使用 :hover 屬性, 并用 display:block; 顯示隱藏的標簽.
但由于瀏覽器對 CSS 的支持并非一致.
對于 Opera 或者 Firefox, 我們可以編寫出純 CSS 菜單, 他們支持任何標簽的 :hover 屬性.
而對于 IE 瀏覽器, :hover 只對 a 標簽起作用, 但我們可以使用腳本的 onmouseover, onmouseout 模擬出其他標簽的 :hover 屬性.
因此編寫適用于 IE 的 CSS 彈出菜單必須使用到少許的腳本.
目錄:
1. 編寫直排右側彈出的 CSS 菜單.
1.1 真正的基于 Opera, Firefox 純 CSS 彈出菜單
1.2 兼容 IE, Opera, Firefox 的 CSS 彈出菜單(腳本實現)
2. 編寫橫排底部彈出的 CSS 菜單.
2.1 真正的基于 Opera, Firefox 純 CSS 彈出菜單
2.2 兼容 IE, Opera, Firefox 的 CSS 彈出菜單(腳本實現)
3. 結論
4. 預覽
shawl.qiu
2006-10-01
http://blog.csdn.NET/btbtd
1. 編寫直排右側彈出的 CSS 菜單.
1.1 真正的基于 Opera, Firefox 純 CSS 彈出菜單- linenum
- <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
- " http://www.w3.org/TR/html4/loose.dtd">
- <html>
- <head>
- <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
- <title>Untitled Document</title>
- <style type="text/css">
- /*<![CDATA[*/ /* shawl.qiu pure css popup menu demo */
- body{ margin:0px auto; width:768px; /* 定義頁面居中顯示,*/}
- *{text-decoration:none!important; /* 定義所有鏈接不顯示下劃線 */}
- .pmVerticalRightOut{background-color:#fff!important; /* 定義主菜單域背景色 */}
- .pmVerticalRightOut .level{ /* 定義一級類別屬性 */
- width:120px; /* 寬度 */
- height:17; /* 高度 */
- position:relative; /* 顯示位置為相對位置 */
- display:block; /* 以塊模式顯示 */
- background-color:#D8D8D8; /* 背景色 */
- padding:0px 2px; /* 文字內補丁間隔 */
- margin:0px 0px 1px 0px; /* 菜單外補丁間隔 */
- }
- .pmVerticalRightOut .level:hover { /* 當鼠標劃過一級菜單時 */
- background-color:#6633FF; /* 背景色 */
- color:#FFFFFF; /* 文字顏色 */
- }
- .pmVerticalRightOut .level_{display:none; /* 默認隱藏二級類別 */}
- .pmVerticalRightOut .level:hover .level_ { /* 鼠標劃過時觸發顯示二級類別 */
- display:block; /* 以塊顯示 */
- left:124px; /* 相對于一級類別顯示的位置 */
- width:120px; /* 寬度 */
- height:auto; /* 高度 */
- top:0px; /* 相對于一級類別所在位置的頂端 */
- background-color:#EFEFEF; /* 定義背景色 */
- position:absolute; /* 位置為絕對位置 */
- }
- .pmVerticalRightOut .level:hover .level_ .level_title {
- /* 定義二級類別標題樣式 */
- font-weight:bold; /* 字體加粗 */
- background-color:#A7ADFE; /* 背景色 */
- color:white; /* 文字顏色 */
- }
- .pmVerticalRightOut .level:hover .level_ a:hover {
- /* 定義二級類別鏈接顯示樣式 */
- background-color:#F83658; /* 背景色 */
- color:white; /* 文字顏色 */
- }
- .pmVerticalRightOut .level_ * {
- /* 定義所有二級類別通用屬性 */
- display:block; /* 以塊顯示 */
- color:black; /* 文字顏色 */
- padding:0px 2px; /* 內補丁間隔 */
- }
- /*]]>*/
- </style>
- </head>
- <body>
- <p/><p/><p/><p/><p/>
- <div class="pmVerticalRightOut" id="pmVerticalRightOut">
- <div class="level">
- <div class="levelTitle">level</div>
- <div class="level_">
- <div class="level_title">level_ title</div>
- <a href="?cat=level&id=1">level_ title 1</a>
- <a href="?cat=level&id=2">level_ title 2</a>
- <a href="?cat=level&id=3">level_ title 3</a>
- <a href="?cat=level&id=4">level_ title 4</a>
- <a href="?cat=level&id=5">level_ title 5</a>
- </div>
- </div>
- <div class="level">
- <div class="levelTitle">level 1</div>
- <div class="level_">
- <div class="level_title">level_ title</div>
- <a href="?cat=level_1&id=1">level_ title 1</a>
- <a href="?cat=level_1&id=2">level_ title 2</a>
- <a href="?cat=level_1&id=3">level_ title 3</a>
- <a href="?cat=level_1&id=4">level_ title 4</a>
- <a href="?cat=level_1&id=5">level_ title 5</a>
- </div>
- </div>
- <div class="level">
- <div class="levelTitle">level 2</div>
- <div class="level_">
- <div class="level_title">level_ title</div>
- <a href="?cat=level_2&id=1">level_ title 1</a>
- <a href="?cat=level_2&id=2">level_ title 2</a>
- <a href="?cat=level_2&id=3">level_ title 3</a>
- <a href="?cat=level_2&id=4">level_ title 4</a>
- <a href="?cat=level_2&id=5">level_ title 5</a>
- </div>
- </div>
- <div class="level">
- <div class="levelTitle">level 3</div>
- <div class="level_">
- <div class="level_title">level_ title</div>
- <a href="?cat=level_3&id=1">level_ title 1</a>
- <a href="?cat=level_3&id=2">level_ title 2</a>
- <a href="?cat=level_3&id=3">level_ title 3</a>
- <a href="?cat=level_3&id=4">level_ title 4</a>
- <a href="?cat=level_3&id=5">level_ title 5</a>
- </div>
- </div>
- <div class="level">
- <div class="levelTitle">level 4</div>
- <div class="level_">
- <div class="level_title">level_ title</div>
- <a href="?cat=level_4&id=1">level_ title 1</a>
- <a href="?cat=level_4&id=2">level_ title 2</a>
- <a href="?cat=level_4&id=3">level_ title 3</a>
- <a href="?cat=level_4&id=4">level_ title 4</a>
- <a href="?cat=level_4&id=5">level_ title 5</a>
- </div>
- </div>
- </div>
- </body>
- </html>
1.2 兼容 IE, Opera, Firefox 的 CSS 彈出菜單(腳本實現)- linenum
- <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
- " http://www.w3.org/TR/html4/loose.dtd">
- <html>
- <head>
- <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
- <title>Untitled Document</title>
- <style type="text/css">
- /*<![CDATA[*/ /* shawl.qiu pure css popup menu demo */
- body{ margin:0px auto; width:768px; /* 定義頁面居中顯示,*/}
- *{text-decoration:none!important; /* 定義所有鏈接不顯示下劃線 */}
- /* ------------------- start 針對 Opera, Firefox 的 CSS 彈出菜單 -------------------*/
- .pmVerticalRightOut{background-color:#fff!important; /* 定義主菜單域背景色 */}
- .pmVerticalRightOut .level{ /* 定義一級類別屬性 */
- width:120px; /* 寬度 */
- height:17; /* 高度 */
- position:relative; /* 顯示位置為相對位置 */
- display:block; /* 以塊模式顯示 */
- background-color:#D8D8D8; /* 背景色 */
- padding:0px 2px; /* 文字內補丁間隔 */
- margin:0px 0px 1px 0px; /* 菜單外補丁間隔 */
- }
- .pmVerticalRightOut .level:hover { /* 當鼠標劃過一級菜單時 */
- background-color:#6633FF; /* 背景色 */
- color:#FFFFFF; /* 文字顏色 */
- }
- .pmVerticalRightOut .level_{display:none; /* 默認隱藏二級類別 */}
- .pmVerticalRightOut .level:hover .level_ { /* 鼠標劃過時觸發顯示二級類別 */
- display:block; /* 以塊顯示 */
- left:124px; /* 相對于一級類別顯示的位置 */
- width:120px; /* 寬度 */
- height:auto; /* 高度 */
- top:0px; /* 相對于一級類別所在位置的頂端 */
- background-color:#EFEFEF; /* 定義背景色 */
- position:absolute; /* 位置為絕對位置 */
- }
- .pmVerticalRightOut .level:hover .level_ .level_title {
- /* 定義二級類別標題樣式 */
- font-weight:bold; /* 字體加粗 */
- background-color:#A7ADFE; /* 背景色 */
- color:white; /* 文字顏色 */
- }
- .pmVerticalRightOut .level:hover .level_ a:hover {
- /* 定義二級類別鏈接顯示樣式 */
- background-color:#F83658; /* 背景色 */
- color:white; /* 文字顏色 */
- }
- .pmVerticalRightOut .level:hover .level_ * {
- /* 定義所有二級類別通用屬性 */
- display:block; /* 以塊顯示 */
- color:black; /* 文字顏色 */
- padding:0px 2px; /* 內補丁間隔 */
- }
- /* ------------------- end 針對 Opera, Firefox 的 CSS 彈出菜單 -------------------*/
- /* ------------------- start 針對 IE 的 CSS 彈出菜單 -------------------*/
- .levelIe{ /* 定義一級類別屬性 */
- width:120px; /* 寬度 */
- height:17; /* 高度 */
- position:relative; /* 顯示位置為相對位置 */
- display:block; /* 以塊模式顯示 */
- background-color:#D8D8D8; /* 背景色 */
- padding:0px 2px; /* 文字內補丁間隔 */
- margin:0px 0px 1px 0px; /* 菜單外補丁間隔 */
- }
- .levelIe .level_ { /* 鼠標劃過時觸發顯示二級類別 */
- display:block; /* 以塊顯示 */
- left:124px; /* 相對于一級類別顯示的位置 */
- width:120px; /* 寬度 */
- height:auto; /* 高度 */
- top:0px; /* 相對于一級類別所在位置的頂端 */
- background-color:#EFEFEF; /* 定義背景色 */
- position:absolute; /* 位置為絕對位置 */
- }
- .levelIe .level_ .level_title {
- /* 定義二級類別標題樣式 */
- font-weight:bold; /* 字體加粗 */
- background-color:#A7ADFE; /* 背景色 */
- color:white; /* 文字顏色 */
- }
- .levelIe .level_ a:hover {
- /* 定義二級類別鏈接顯示樣式 */
- background-color:#F83658; /* 背景色 */
- color:white; /* 文字顏色 */
- }
- .levelIe .level_ * {
- /* 定義所有二級類別通用屬性 */
- display:block; /* 以塊顯示 */
- color:black; /* 文字顏色 */
- padding:0px 2px; /* 內補丁間隔 */
- }
- /* ------------------- end 針對 IE 的 CSS 彈出菜單 -------------------*/
- /*]]>*/
- </style>
- <script type="text/Javascript">
- //<![CDATA[
- if (navigator.appName=="Microsoft InterNET Explorer") {
- function fPmVerticalRightOut() {
- var getItem = document.getElementById("pmVerticalRightOut").getElementsByTagName("div");
- for (var i=0; i<getItem.length; i++) {
- getItem[i].onmouseover=function() {
- if( this.className=="level"){
- this.className="levelIe";
- }
- }
- getItem[i].onmouseout=function() {
- if( this.className=="levelIe"){
- this.className="level";
- }
- }//css popup menu script by shawl.qiu
- }
- }
- window.onload=fPmVerticalRightOut;
- }
- //]]>
- </script>
- </head>
- <body>
- <p/><p/><p/><p/><p/>
- <div class="pmVerticalRightOut" id="pmVerticalRightOut">
- <div class="level">
- <div class="levelTitle">level</div>
- <div class="level_">
- <div class="level_title">level_ title</div>
- <a href="?cat=level&id=1">level_ title 1</a>
- <a href="?cat=level&id=2">level_ title 2</a>
- <a href="?cat=level&id=3">level_ title 3</a>
- <a href="?cat=level&id=4">level_ title 4</a>
- <a href="?cat=level&id=5">level_ title 5</a>
- </div>
- </div>
- <div class="level">
- <div class="levelTitle">level 1</div>
- <div class="level_">
- <div class="level_title">level_ title</div>
- <a href="?cat=level_1&id=1">level_ title 1</a>
- <a href="?cat=level_1&id=2">level_ title 2</a>
- <a href="?cat=level_1&id=3">level_ title 3</a>
- <a href="?cat=level_1&id=4">level_ title 4</a>
- <a href="?cat=level_1&id=5">level_ title 5</a>
- </div>
- </div>
- <div class="level">
- <div class="levelTitle">level 2</div>
- <div class="level_">
- <div class="level_title">level_ title</div>
- <a href="?cat=level_2&id=1">level_ title 1</a>
- <a href="?cat=level_2&id=2">level_ title 2</a>
- <a href="?cat=level_2&id=3">level_ title 3</a>
- <a href="?cat=level_2&id=4">level_ title 4</a>
- <a href="?cat=level_2&id=5">level_ title 5</a>
- </div>
- </div>
- <div class="level">
- <div class="levelTitle">level 3</div>
- <div class="level_">
- <div class="level_title">level_ title</div>
- <a href="?cat=level_3&id=1">level_ title 1</a>
- <a href="?cat=level_3&id=2">level_ title 2</a>
- <a href="?cat=level_3&id=3">level_ title 3</a>
- <a href="?cat=level_3&id=4">level_ title 4</a>
- <a href="?cat=level_3&id=5">level_ title 5</a>
- </div>
- </div>
- <div class="level">
- <div class="levelTitle">level 4</div>
- <div class="level_">
- <div class="level_title">level_ title</div>
- <a href="?cat=level_4&id=1">level_ title 1</a>
- <a href="?cat=level_4&id=2">level_ title 2</a>
- <a href="?cat=level_4&id=3">level_ title 3</a>
- <a href="?cat=level_4&id=4">level_ title 4</a>
- <a href="?cat=level_4&id=5">level_ title 5</a>
- </div>
- </div>
- </div>
- </body>
- </html>
2. 編寫橫排底部彈出的 CSS 菜單.
2.1 真正的基于 Opera, Firefox 純 CSS 彈出菜單- linenum
- <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
- " http://www.w3.org/TR/html4/loose.dtd">
- <html>
- <head>
- <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
- <title>Untitled Document</title>
- <style type="text/css">
- /*<![CDATA[*/ /* shawl.qiu pure css popup menu demo */
- body{ margin:0px auto; width:768px; /* 定義頁面居中顯示,*/}
- *{text-decoration:none!important; /* 定義所有鏈接不顯示下劃線 */}
- .pmHorizontalBottomOut{background-color:#fff!important; /* 定義主菜單域背景色 */}
- .pmHorizontalBottomOut .level{ /* 定義一級類別屬性 */
- width:120px; /* 寬度 */
- height:17; /* 高度 */
- position:relative; /* 顯示位置為相對位置 */
- display:block; /* 以塊模式顯示 */
- background-color:#D8D8D8; /* 背景色 */
- padding:0px 2px; /* 文字內補丁間隔 */
- margin:0px 1px 0px 0px; /* 菜單外補丁間隔 */
- float:left;
- }
- .pmHorizontalBottomOut .level:hover { /* 當鼠標劃過一級菜單時 */
- background-color:#6633FF; /* 背景色 */
- color:#FFFFFF; /* 文字顏色 */
- }
- .pmHorizontalBottomOut .level_{display:none; /* 默認隱藏二級類別 */}
- .pmHorizontalBottomOut .level:hover .level_ { /* 鼠標劃過時觸發顯示二級類別 */
- display:block; /* 以塊顯示 */
- width:124px; /* 寬度 */
- height:auto; /* 高度 */
- margin:0px -2px 0px -2px; /* 外補丁 */
- background-color:#EFEFEF; /* 定義背景色 */
- position:absolute; /* 位置為絕對位置 */
- }
- .pmHorizontalBottomOut .level:hover .level_ .level_title {
- /* 定義二級類別標題樣式 */
- font-weight:bold; /* 字體加粗 */
- background-color:#A7ADFE; /* 背景色 */
- color:white; /* 文字顏色 */
- }
- .pmHorizontalBottomOut .level:hover .level_ a:hover {
- /* 定義二級類別鏈接顯示樣式 */
- background-color:#F83658; /* 背景色 */
- color:white; /* 文字顏色 */
- }
- .pmHorizontalBottomOut .level_ * {
- /* 定義所有二級類別通用屬性 */
- display:block; /* 以塊顯示 */
- color:black; /* 文字顏色 */
- padding:0px 2px; /* 內補丁間隔 */
- }
- /*]]>*/
- </style>
- </head>
- <body>
- <p/><p/><p/><p/><p/>
- <div class="pmHorizontalBottomOut" id="pmHorizontalBottomOut">
- <div class="level">
- <div class="levelTitle">level</div>
- <div class="level_">
- <div class="level_title">level_ title</div>
- <a href="?cat=level&id=1">level_ title 1</a>
- <a href="?cat=level&id=2">level_ title 2</a>
- <a href="?cat=level&id=3">level_ title 3</a>
- <a href="?cat=level&id=4">level_ title 4</a>
- <a href="?cat=level&id=5">level_ title 5</a>
- </div>
- </div>
- <div class="level">
- <div class="levelTitle">level 1</div>
- <div class="level_">
- <div class="level_title">level_ title</div>
- <a href="?cat=level_1&id=1">level_ title 1</a>
- <a href="?cat=level_1&id=2">level_ title 2</a>
- <a href="?cat=level_1&id=3">level_ title 3</a>
- <a href="?cat=level_1&id=4">level_ title 4</a>
- <a href="?cat=level_1&id=5">level_ title 5</a>
- </div>
- </div>
- <div class="level">
- <div class="levelTitle">level 2</div>
- <div class="level_">
- <div class="level_title">level_ title</div>
- <a href="?cat=level_2&id=1">level_ title 1</a>
- <a href="?cat=level_2&id=2">level_ title 2</a>
- <a href="?cat=level_2&id=3">level_ title 3</a>
- <a href="?cat=level_2&id=4">level_ title 4</a>
- <a href="?cat=level_2&id=5">level_ title 5</a>
- </div>
- </div>
- <div class="level">
- <div class="levelTitle">level 3</div>
- <div class="level_">
- <div class="level_title">level_ title</div>
- <a href="?cat=level_3&id=1">level_ title 1</a>
- <a href="?cat=level_3&id=2">level_ title 2</a>
- <a href="?cat=level_3&id=3">level_ title 3</a>
- <a href="?cat=level_3&id=4">level_ title 4</a>
- <a href="?cat=level_3&id=5">level_ title 5</a>
- </div>
- </div>
- <div class="level">
- <div class="levelTitle">level 4</div>
- <div class="level_">
- <div class="level_title">level_ title</div>
- <a href="?cat=level_4&id=1">level_ title 1</a>
- <a href="?cat=level_4&id=2">level_ title 2</a>
- <a href="?cat=level_4&id=3">level_ title 3</a>
- <a href="?cat=level_4&id=4">level_ title 4</a>
- <a href="?cat=level_4&id=5">level_ title 5</a>
- </div>
- </div>
- </div>
- </body>
- </html>
2.2 兼容 IE, Opera, Firefox 的 CSS 彈出菜單(腳本實現)- linenum
- <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
- " http://www.w3.org/TR/html4/loose.dtd">
- <html>
- <head>
- <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
- <title>Untitled Document</title>
- <style type="text/css">
- /*<![CDATA[*/ /* shawl.qiu pure css popup menu demo */
- body{ margin:0px auto; width:768px; /* 定義頁面居中顯示,*/}
- *{text-decoration:none!important; /* 定義所有鏈接不顯示下劃線 */}
- /* ------------------- start 針對 Opera, Firefox 的 CSS 彈出菜單 -------------------*/
- .pmHorizontalBottomOut{background-color:#fff!important; /* 定義主菜單域背景色 */}
- .pmHorizontalBottomOut .level{ /* 定義一級類別屬性 */
- width:120px; /* 寬度 */
- height:17; /* 高度 */
- position:relative; /* 顯示位置為相對位置 */
- display:block; /* 以塊模式顯示 */
- background-color:#D8D8D8; /* 背景色 */
- padding:0px 2px; /* 文字內補丁間隔 */
- margin:0px 1px 0px 0px; /* 菜單外補丁間隔 */
- float:left;
- }
- .pmHorizontalBottomOut .level:hover { /* 當鼠標劃過一級菜單時 */
- background-color:#6633FF; /* 背景色 */
- color:#FFFFFF; /* 文字顏色 */
- }
- .pmHorizontalBottomOut .level_{display:none; /* 默認隱藏二級類別 */}
- .pmHorizontalBottomOut .level:hover .level_ { /* 鼠標劃過時觸發顯示二級類別 */
- display:block; /* 以塊顯示 */
- width:124px; /* 寬度 */
- height:auto; /* 高度 */
- margin:0px -2px 0px -2px; /* 外補丁 */
- background-color:#EFEFEF; /* 定義背景色 */
- position:absolute; /* 位置為絕對位置 */
- }
- .pmHorizontalBottomOut .level:hover .level_ .level_title {
- /* 定義二級類別標題樣式 */
- font-weight:bold; /* 字體加粗 */
- background-color:#A7ADFE; /* 背景色 */
- color:white; /* 文字顏色 */
- }
- .pmHorizontalBottomOut .level:hover .level_ a:hover {
- /* 定義二級類別鏈接顯示樣式 */
- background-color:#F83658; /* 背景色 */
- color:white; /* 文字顏色 */
- }
- .pmHorizontalBottomOut .level_ * {
- /* 定義所有二級類別通用屬性 */
- display:block; /* 以塊顯示 */
- color:black; /* 文字顏色 */
- padding:0px 2px; /* 內補丁間隔 */
- }
- /* ------------------- end 針對 Opera, Firefox 的 CSS 彈出菜單 -------------------*/
- /* ------------------- start 針對 IE 的 CSS 彈出菜單 -------------------*/
- .levelIe{ /* 定義一級類別屬性 */
- width:120px; /* 寬度 */
- height:17; /* 高度 */
- position:relative; /* 顯示位置為相對位置 */
- display:block; /* 以塊模式顯示 */
- background-color:#D8D8D8; /* 背景色 */
- padding:0px 2px; /* 文字內補丁間隔 */
- margin:0px 1px 0px 0px; /* 菜單外補丁間隔 */
- float:left;
- }
- .levelIe { /* 當鼠標劃過一級菜單時 */
- background-color:#6633FF; /* 背景色 */
- color:#FFFFFF; /* 文字顏色 */
- }
- .levelIe .level_ { /* 鼠標劃過時觸發顯示二級類別 */
- display:block; /* 以塊顯示 */
- width:124px; /* 寬度 */
- height:auto; /* 高度 */
- margin:0px -2px 0px -2px; /* 外補丁 */
- background-color:#EFEFEF; /* 定義背景色 */
- position:absolute; /* 位置為絕對位置 */
- }
- .levelIe .level_ .level_title {
- /* 定義二級類別標題樣式 */
- font-weight:bold; /* 字體加粗 */
- background-color:#A7ADFE; /* 背景色 */
- color:white; /* 文字顏色 */
- }
- .levelIe .level_ a:hover {
- /* 定義二級類別鏈接顯示樣式 */
- background-color:#F83658; /* 背景色 */
- color:white; /* 文字顏色 */
- }
- .levelIe .level_ * {
- /* 定義所有二級類別通用屬性 */
- display:block; /* 以塊顯示 */
- color:black; /* 文字顏色 */
- padding:0px 2px; /* 內補丁間隔 */
- }
- /* ------------------- end 針對 IE 的 CSS 彈出菜單 -------------------*/
- /*]]>*/
- </style>
- <script type="text/Javascript">
- //<![CDATA[
- if (navigator.appName=="Microsoft InterNET Explorer") {
- function fPmHorizontalBottomOut() {
- var getItem = document.getElementById("pmHorizontalBottomOut").getElementsByTagName("div");
- for (var i=0; i<getItem.length; i++) {
- getItem[i].onmouseover=function() {
- if( this.className=="level"){
- this.className="levelIe";
- }
- }
- getItem[i].onmouseout=function() {
- if( this.className=="levelIe"){
- this.className="level";
- }
- }//css popup menu script by shawl.qiu
- }
- }
- window.onload=fPmHorizontalBottomOut;
- }
- //]]>
- </script>
- </head>
- <body>
- <p/><p/><p/><p/><p/>
- <div class="pmHorizontalBottomOut" id="pmHorizontalBottomOut">
- <div class="level">
- <div class="levelTitle">level</div>
- <div class="level_">
- <div class="level_title">level_ title</div>
- <a href="?cat=level&id=1">level_ title 1</a>
- <a href="?cat=level&id=2">level_ title 2</a>
- <a href="?cat=level&id=3">level_ title 3</a>
- <a href="?cat=level&id=4">level_ title 4</a>
- <a href="?cat=level&id=5">level_ title 5</a>
- </div>
- </div>
- <div class="level">
- <div class="levelTitle">level 1</div>
- <div class="level_">
- <div class="level_title">level_ title</div>
- <a href="?cat=level_1&id=1">level_ title 1</a>
- <a href="?cat=level_1&id=2">level_ title 2</a>
- <a href="?cat=level_1&id=3">level_ title 3</a>
- <a href="?cat=level_1&id=4">level_ title 4</a>
- <a href="?cat=level_1&id=5">level_ title 5</a>
- </div>
- </div>
- <div class="level">
- <div class="levelTitle">level 2</div>
- <div class="level_">
- <div class="level_title">level_ title</div>
- <a href="?cat=level_2&id=1">level_ title 1</a>
- <a href="?cat=level_2&id=2">level_ title 2</a>
- <a href="?cat=level_2&id=3">level_ title 3</a>
- <a href="?cat=level_2&id=4">level_ title 4</a>
- <a href="?cat=level_2&id=5">level_ title 5</a>
- </div>
- </div>
- <div class="level">
- <div class="levelTitle">level 3</div>
- <div class="level_">
- <div class="level_title">level_ title</div>
- <a href="?cat=level_3&id=1">level_ title 1</a>
- <a href="?cat=level_3&id=2">level_ title 2</a>
- <a href="?cat=level_3&id=3">level_ title 3</a>
- <a href="?cat=level_3&id=4">level_ title 4</a>
- <a href="?cat=level_3&id=5">level_ title 5</a>
- </div>
- </div>
- <div class="level">
- <div class="levelTitle">level 4</div>
- <div class="level_">
- <div class="level_title">level_ title</div>
- <a href="?cat=level_4&id=1">level_ title 1</a>
- <a href="?cat=level_4&id=2">level_ title 2</a>
- <a href="?cat=level_4&id=3">level_ title 3</a>
- <a href="?cat=level_4&id=4">level_ title 4</a>
- <a href="?cat=level_4&id=5">level_ title 5</a>
- </div>
- </div>
- </div>
- </body>
- </html>
3. 結論
以上例子可以看出, 如果已經編寫出一個可用的CSS彈出菜單例子, 那要編寫出彈出位置在其他地方的 CSS 彈出菜單的話, 只須小小修改一下就 OK.
4. 預覽
4.1 1.2 兼容 IE, Opera, Firefox 的 CSS 彈出菜單(腳本實現) 的預覽- levellevel_ titlelevel_ title 1 level_ title 2 level_ title 3 level_ title 4 level_ title 5 level 1level_ titlelevel_ title 1 level_ title 2 level_ title 3 level_ title 4 level_ title 5 level 2level_ titlelevel_ title 1 level_ title 2 level_ title 3 level_ title 4 level_ title 5 level 3level_ titlelevel_ title 1 level_ title 2 level_ title 3 level_ title 4 level_ title 5 level 4level_ titlelevel_ title 1 level_ title 2 level_ title 3 level_ title 4 level_ title 5
4.2 2.2 兼容 IE, Opera, Firefox 的 CSS 彈出菜單(腳本實現) 的預覽- levellevel_ titlelevel_ title 1 level_ title 2 level_ title 3 level_ title 4 level_ title 5 level 1level_ titlelevel_ title 1 level_ title 2 level_ title 3 level_ title 4 level_ title 5 level 2level_ titlelevel_ title 1 level_ title 2 level_ title 3 level_ title 4 level_ title 5 level 3level_ titlelevel_ title 1 level_ title 2 level_ title 3 level_ title 4 level_ title 5 level 4level_ titlelevel_ title 1 level_ title 2 level_ title 3 level_ title 4 level_ title 5
HTML/CSS技術:編寫純 CSS 彈出菜單的原理及實現 By shawl.qiu,轉載需保留來源!
鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。